Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 17.04.2010
Сообщений: 9
1

Подпрограммы (procedure)

18.04.2010, 17:28. Показов 777. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Дан массив {Xij}, i=1..L, j=1..L. L - целое, не больше 20. Записать положительные элементы главной и побочной диагоналей соответственно в массивы {Wk} и {Vn}, расположив их в порядке возрастания. Использовать PROCEDURE.
Помогите пожалуйста написать программу
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.04.2010, 17:28
Ответы с готовыми решениями:

Составление прогами по использованию подпрограммы процедур и подпрограммы функций
Записать программу решения задачи. Процедуру вычислений повторяющихся записать в виде подпрограммы....

Procedure
Заданы три массива: A(1)...A(11) B(1)...B(11) C(1)...C(11) Определить Y=(SA-SC)/SB и Z=...

Procedure
Найдите элементы каждой строки матрицы, которые повторяются наибольшее число раз в своей строке.

Procedure
Здраствуйте! Осваиваю Pascal и вот не магу процеДУРУ сделать!! заранее очень БЛАГОДАРЕН, т.к....

3
ЧакЭ одобряЭ
285 / 284 / 86
Регистрация: 27.12.2009
Сообщений: 1,767
18.04.2010, 18:27 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
77
78
79
80
81
82
83
uses
  crt;
 
type
  tmat = array[1..20, 1..20] of integer;
 
procedure zapis(a: tmat; l: integer);
var
  i, j, k, m, x: integer;
  b, c: array[1..20] of integer;
begin
  k := 0;
  m := 0;
  for i := 1 to l do 
  begin
    for j := 1 to l do 
      if (i = j) and (a[i, j] > 0) then begin
        k := k + 1;
        b[k] := a[i, j];
      end;
  end;
  for i := 1 to l do 
  begin
    for j := 1 to l do 
      if (i + j - 1 = l) and (a[i, j] > 0) then begin
        m := m + 1;
        c[m] := a[i, j];
      end;
  end;
  writeln;
  for i := 1 to k - 1 do 
  begin
    for j := k - 1 downto 1 do
      if b[j] > b[j + 1] then begin
        x := b[j];
        b[j] := b[j + 1];
        b[j + 1] := x;
      end;
  end;
  for i := 1 to m - 1 do 
  begin
    for j := m - 1 downto 1 do
      if c[j] > c[j + 1] then begin
        x := c[j];
        c[j] := c[j + 1];
        c[j + 1] := x;
      end;
  end;
  writeln('первый массив');
  for i := 1 to k do 
  begin
    write(b[i], ' ');
  end;
  readln;
  writeln('второй массив');
  for i := 1 to m do 
  begin
    write(c[i], ' ');
  end;
end;
 
var
  i, j, l: integer;
  a: tmat;
 
begin
  randomize;
  writeln('введите l');
  readln(l);
  for i := 1 to l do 
  begin
    for j := 1 to l do
      a[i, j] := random(10) - 1;
  end;
  for i := 1 to l do 
  begin
    for j := 1 to l do
      write(a[i, j], ' ');
    writeln;
  end;
  zapis(a, l);
  readln;
end.
1
0 / 0 / 0
Регистрация: 14.04.2010
Сообщений: 25
18.04.2010, 20:37 3
Даны массивы:
A={Aij}, i=1..N1, j=1..N1
B={Bij}, i=1..N2, j=1..N2
C={Cij}, i=1..N3, j=1..N3
N1,N2,N3 - целые не больше 10,15 и 20. Вычислить сумму и количество положительных элементов, стоящих на чётных местах в первом столбце. Результаты получить отдельно для каждого массива.
Использовать PROCEDURE
0
ЧакЭ одобряЭ
285 / 284 / 86
Регистрация: 27.12.2009
Сообщений: 1,767
18.04.2010, 20:54 4
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
type
 mass=array[1..100,1..100] of integer;
 
procedure summik(n:mass;k:integer);
var
i,j:integer;
sum,kol:real;
 
begin
for i:=1 to k do begin
 for j:=1 to k do 
  if (j=1) and (i mod 2=0) and (n[i,j]>0) then begin
   sum:=sum+n[i,j];
   kol:=kol+1;
  end;
 end;
write('сумма-',' ',sum,' ','кол-во-',' ',kol);
end;
var
a,b,c:mass;
i,j,n1,n2,n3:integer;
 
begin
randomize;
repeat
writeln('введите размерность массива 1');
readln(n1);
until n1 in [2..10];
for i:=1 to n1 do begin
 for j:=1 to n1 do
  a[i,j]:=random(10)-3;
end;
writeln('первая матрица');
for i:=1 to n1 do begin
 for j:=1 to n1 do
  write(a[i,j],' ');
  writeln;
end;
summik(a,n1);
writeln;
repeat
writeln('введите размерность массива 2');
readln(n2);
until n1 in [2..15];
for i:=1 to n2 do begin
 for j:=1 to n2 do
  b[i,j]:=random(10)-3;
end;
writeln('вторая матрица');
for i:=1 to n2 do begin
 for j:=1 to n2 do
  write(b[i,j],' ');
  writeln;
end;
summik(b,n2);
writeln;
repeat
writeln('введите размерность массива 3');
readln(n3);
until n3 in [2..20];
for i:=1 to n3 do begin
 for j:=1 to n3 do
  c[i,j]:=random(10)-3;
end;
writeln('третья матрица');
for i:=1 to n3 do begin
 for j:=1 to n3 do
  write(c[i,j],' ');
  writeln;
end;
summik(c,n3);
end.type
  mass = array[1..100, 1..100] of integer;
 
procedure summik(n: mass; k: integer);
var
  i, j: integer;
  sum, kol: real;
 
begin
  for i := 1 to k do 
  begin
    for j := 1 to k do 
      if (j = 1) and (i mod 2 = 0) and (n[i, j] > 0) then begin
        sum := sum + n[i, j];
        kol := kol + 1;
      end;
  end;
  write('сумма-', ' ', sum, ' ', 'кол-во-', ' ', kol);
end;
 
var
  a, b, c: mass;
  i, j, n1, n2, n3: integer;
 
begin
  randomize;
  repeat
    writeln('введите размерность массива 1');
    readln(n1);
  until n1 in [2..10];
  for i := 1 to n1 do 
  begin
    for j := 1 to n1 do
      a[i, j] := random(10) - 3;
  end;
  writeln('первая матрица');
  for i := 1 to n1 do 
  begin
    for j := 1 to n1 do
      write(a[i, j], ' ');
    writeln;
  end;
  summik(a, n1);
  writeln;
  repeat
    writeln('введите размерность массива 2');
    readln(n2);
  until n1 in [2..15];
  for i := 1 to n2 do 
  begin
    for j := 1 to n2 do
      b[i, j] := random(10) - 3;
  end;
  writeln('вторая матрица');
  for i := 1 to n2 do 
  begin
    for j := 1 to n2 do
      write(b[i, j], ' ');
    writeln;
  end;
  summik(b, n2);
  writeln;
  repeat
    writeln('введите размерность массива 3');
    readln(n3);
  until n3 in [2..20];
  for i := 1 to n3 do 
  begin
    for j := 1 to n3 do
      c[i, j] := random(10) - 3;
  end;
  writeln('третья матрица');
  for i := 1 to n3 do 
  begin
    for j := 1 to n3 do
      write(c[i, j], ' ');
    writeln;
  end;
  summik(c, n3);
end.
можно конечно было реализовать ввод матрицы через процедуру.тогда было бы короче
0
18.04.2010, 20:54
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.04.2010, 20:54
Помогаю со студенческими работами здесь

3адача Procedure
Решите, пожалуйста, эту задачу. Описать процедуру RectPS(x1, y1, x2, y2, P, S), вычисляющую...

Ошибка с procedure
Здравствуйте, как можно исправить ошибку в procedure Print?. Ошибка: Тип параметра или...

Определить площадь области исп. procedure
Написать программу, определяющую площадь области, ограниченной описанным вокруг окружности...

добавила procedure и прога перестала работать
Помогите пожалуйста не могу разобраться почему когда я добавила procedure...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru