Форум программистов, компьютерный форум, киберфорум
Наши страницы
Turbo Pascal
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
Ильнар
0 / 0 / 0
Регистрация: 17.05.2012
Сообщений: 43
1

Определить произведение элементов в тех строках, которые не содержат отрицательных элементов

07.11.2012, 13:00. Просмотров 2103. Ответов 2
Метки нет (Все метки)

Дана целочисленная квадратная матрица. Определить:
1) произведение элементов в тех строках, которые не содержат отрицательных элементов (оформить в виде функции)
2) максимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы ( оформить в иде процедуры)
Я код написал, теперь нужно оформить в виде функции и процедуры, не знаю как что делать, помогите пожалуйста!)

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
uses crt;
const nmax=20;
var a:array[1..nmax,1..nmax]of integer;
    n,i,j,sum,k,max,l:integer;
    p:longint;
begin
clrscr;
randomize;
repeat
write('Vvedite razmernost matricy do ',nmax,' n= ');
readln(n);
until n in [1..nmax];
Writeln('Matrica:');
for i:=1 to n do
   begin
     for j:=1 to n  do
       begin
        repeat
        a[i,j]:=random(10)-2;
        until a[i,j]<>0;
        write(a[i,j]:4);
       end;
     writeln;
   end;
for i:=1 to n do
 begin
  k:=0;
  for j:=1 to n do
  if a[i,j]<0 then k:=1;
  if k=0 then
   begin
    p:=1;
    for l:=1 to n do
    p:=p*a[i,l];
    writeln('Proizvedenie v stroke ',i,'=',p);
   end;
 end;
write('Press Enter...');
readln;
max:=a[n,1];
for l:=1 to 2*n-1 do{количество диагоналей}
  begin
    sum:=0;
    if l<n then{если брать и главную, то if l<=n}
      begin
       for i:=n-l+1 to n do
       for j:=1 to l do
       if j=i-n+l then sum:=sum+a[i,j];
       writeln('Сумма ',l,'=',sum);
       if sum>max then max:=sum;
      end
    else if l>n then
      begin
       for i:=1 to 2*n-l do
       for j:=l-n+1 to n do
       if j=i+l-n then sum:=sum+a[i,j];
       writeln('Сумма ',l,'=',sum);
       if sum>max then max:=sum;
      end;
  end;
write('Maximalnaya summa=',max);
readln
end.
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.11.2012, 13:00
Ответы с готовыми решениями:

Определить произведение элементов в тех строках, которые не содержат отрицательных элементов
Дана целочисленная прямоугольная матрица. Определить произведение элементов в тех строках, которые...

Определить произведение элементов в тех строках, которые не содержат отрицательных элементов
Дана целочисленная квадратная матрица. Определить: 1. произведение элементов в тех строках,...

Дана целочисленная квадратная матрица.Определить произведение элементов в тех строках которые не содержат отрицательных элементов
знаю только как заполнить матрицу

Найти произведение элементов в тех строках, которые не содержат отрицательных элементов
Дана целочисленная матрица. Определить: 1. произведение элементов в тех строках, которые не...

Найти произведение элементов в тех строках матрицы, которые не содержат отрицательных элементов
Дана целочисленная квадратная матрица. Определить: 1. Произведение элементов в тех строках,...

2
Puporev
Модератор
58933 / 44611 / 30787
Регистрация: 18.05.2008
Сообщений: 106,893
07.11.2012, 14:29 2
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
uses crt;
const nmax=20;
type mtr=array[1..nmax,1..nmax]of integer;
function Proizv(a:mtr;n,k:integer):longint;
var p:longint;
    j:integer;
begin
p:=1;
for j:=1 to n do
p:=p*a[k,j];
Proizv:=p;
end;
procedure Max(a:mtr;n:integer;var mx:integer);
var i,j,l,sm:integer;
begin
mx:=a[n,1];
for l:=1 to 2*n-1 do{количество диагоналей}
  begin
    sm:=0;
    if l<n then{если брать и главную, то if l<=n}
      begin
       for i:=n-l+1 to n do
       for j:=1 to l do
       if j=i-n+l then sm:=sm+a[i,j];
       writeln('Сумма ',l,'=',sm);
       if sm>mx then mx:=sm;
      end
    else if l>n then
      begin
       for i:=1 to 2*n-l do
       for j:=l-n+1 to n do
       if j=i+l-n then sm:=sm+a[i,j];
       writeln('Сумма ',l,'=',sm);
       if sm>mx then mx:=sm;
      end;
  end;
write('Maximalnaya summa=',mx);
end;
var a:mtr;
    n,i,j,k,f,mx:integer;
begin
clrscr;
randomize;
repeat
write('Vvedite razmernost matricy do ',nmax,' n= ');
readln(n);
until n in [1..nmax];
Writeln('Matrica:');
for i:=1 to n do
   begin
     for j:=1 to n  do
       begin
        repeat
        a[i,j]:=random(10)-2;
        until a[i,j]<>0;
        write(a[i,j]:4);
       end;
     writeln;
   end;
f:=0;
for i:=1 to n do
 begin
  k:=0;
  for j:=1 to n do
  if a[i,j]<0 then k:=1;
  if k=0 then
   begin
    f:=1;
    writeln('Proizvedenie v stroke ',i,'=',Proizv(a,n,i));
   end;
 end;
write('Press Enter...');
readln;
Max(a,n,mx);
readln
end.
2
Ильнар
0 / 0 / 0
Регистрация: 17.05.2012
Сообщений: 43
07.11.2012, 15:11  [ТС] 3
спасибо большое!)
0
07.11.2012, 15:11
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.11.2012, 15:11

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Определить сумму элементов в тех строках, которые не содержат отрицательных элементов
Дана целочисленная прямоугольная матрица. Определить: 1. сумму элементов в тех строках, которые не...

Определить сумму элементов в тех строках, которые не содержат отрицательных элементов
Помогите сделать лабу в универ Задача №1 Каждый пункт нижеприведенного задания оформить в виде...

Определить сумму элементов в тех строках матрицы, которые не содержат отрицательных элементов
Дана целочисленная квадратная матрица. Определить: 1) сумму элементов в тех строках, которые не...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.