IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Работа с матрицей
Merlin
сообщение 15.12.2005 19:31
Сообщение #1


Пионер
**

Группа: Пользователи
Сообщений: 114
Пол: Мужской
Реальное имя: Ден

Репутация: -  0  +


Дана матрица A размером m x n , состоящая из натуральных чисел, больших 1.
В этой задаче требуется найти :

1). Строки матрицы упорядочить по невозрастанию произведения элементов строк
2). Составить одномерный массив B, в котором Bj , равен номеру столбца, содержащего только числа, кратные 5, в противном случае Bj = 0.

---------------

Как упорядочить по невозрастанию я знаю, а вот вопрос : Как найти произведение строк blink.gif ?


--------------------
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
Merlin
сообщение 16.12.2005 17:17
Сообщение #2


Пионер
**

Группа: Пользователи
Сообщений: 114
Пол: Мужской
Реальное имя: Ден

Репутация: -  0  +



Program h;
const
m=5;
n=4;
a: array[1..m,1..n] of integer=
(
(3,2,4,6),
(2,5,3,5),
(5,7,3,5),
(4,6,3,2),
(9,5,2,6)
);

Var
i, j , P, count: integer;
B: array[1..100] of integer;

Begin

{ Нахождение произведения элементов строк }

for i:=1 to m do
P:=1;
for j:=1 to n do begin
P:= P * a[i,j];
end;

{ Перестановка строк матрицы по невозрастанию произведений элементво строк }

for i:=1 to m do
for j:=m Down to i+1 do
if a[Pred[j] < a[j] tnen begin
temp:=a[j-1];
a[j-1]:=a[j];
a[j]:= temp;
end;

{ Выполнение 2-го пункта моего задания }
for j := 1 to n do begin

count := 0;
for i := 1 to m do
if (a[i, j] mod 5) = 0 then count := count + 1;

if count = m then B[j] := j
else B[j]:=0;

end;
writeln('Полученный массив B=');
for i:=1 to m do
for j:=1 to n do
write( B[j]);
readln;
end.




Совсем запутался с перестановкой строк по невозрастанию... blink.gif И кажется с произведением что то не так...
Сам знаю что делаю неправильно, но где ошибка ?


--------------------
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 26.07.2025 13:44
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"