![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() |
Neon6868 |
![]() ![]()
Сообщение
#1
|
Пионер ![]() ![]() Группа: Пользователи Сообщений: 146 Пол: Мужской Репутация: ![]() ![]() ![]() |
Задание: Дана целочисленная прямоугольная матрица.Определить количество столбцов,не содержащих ни одного нулевого элемента (оформить в виде функции). Характеристикой строки целочисленной матрицы назовем сумму её положительных четных элементов. Переставляя строки заданной матрицы, расположить их в соответствии с ростом характеристик (оформить в виде процедуры).
Программа неправильно переставляет строки. Я понял, что программа неправильно считает характеристики (в программе выделено синим цветом)! Подскажите почему, вроде бы все написано правильно. Программа: Program HACK;
const
n=3;
m=4;
type
mas1=array [1..n,1..m] of integer;
var
i,j,kol:integer;
a:mas1;
function Nul(a:mas1):integer;
var
i,j:integer;
chis:integer;
mas2:array [1..m] of boolean;
begin
chis:=0;
for i:=1 to m do
mas2[i]:=true;
for j:=1 to m do
for i:=1 to n do
if a[i,j]=0 then mas2[j]:=false;
for j:=1 to m do
if mas2[j]=true then chis:=chis+1;
Nul:=chis;
end;
procedure perestanovka(var a:mas1);
var
mas2:array[1..n] of integer;
min,min_el,l,save:integer;
begin
for i:=1 to n do
mas2[i]:=0;
for i:=1 to n do
for j:=1 to m do
if (a[i,j]>0) and (odd(a[i,j])=false) then
mas2[i]:=mas2[i]+a[i,j];
for j:=1 to n do begin
min:=j;
min_el:=mas2[j];
for i:=j+1 to n do begin
if mas2[i]<min_el then begin
min:=i;
min_el:=mas2[i];
end;
end;
for l:=1 to m do begin
save:=a[min,l];
a[min,l]:=a[j,l];
a[j,l]:=save;
end;
end;
End;
begin
randomize;
write('Isxodnii massiv:');
for i:=1 to n do begin
writeln;
for j:=1 to m do begin
a[i,j]:=random(15)-8;
write (a[i,j],' ');
end;
end;
kol:=Nul(a);
writeln;
write('Kol-vo stolbcov, ne soderzhaschix ni odnogo nulevogo elementa=');
writeln(kol);
Perestanovka(a);
writeln('Preobrazovannii massiv:');
for i:=1 to n do begin
writeln;
for j:=1 to m do
write (a[i,j],' ');
end;
End.
Сообщение отредактировано: Neon6868 - 24.05.2008 22:36 |
![]() ![]() |
![]() |
Текстовая версия | 17.07.2025 20:03 |