• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Двумерные массивы

  • Автор темы Автор темы gaben134
  • Дата начала Дата начала

gaben134

Новые
Регистрация
7 Апр 2016
Сообщения
26
Реакции
0
Баллы
0
Двумерные массивы

Помогите пожалуйста!

Размерности массивов следует задать именованными константами.
Все необходимые данные должны передаваться подпрограммам в
качестве параметров. Все величины, используемые только внутри
подпрограмм, должны быть описаны как локальные. Использование
глобальных переменных в подпрограммах не допускается. Вывод
результатов работы подпрограмм должен выполняться в главной
программе.
1) Для заданной матрицы размером 8x8 найти такие k, что k-я строка
матрицы совпадает с k-м столбцом (оформить в виде процедуры).
2) Найти сумму элементов в тех строках, которые содержат хотя бы
один отрицательный элемент (оформить в виде функции).
 
Помогите пожалуйста!
Помогаю:
Код:
Const
 N=8;

Type
 Matr=Array[1..N,1..N] of Integer;
 Vect=Array[1..N] of Integer;

Var
 i,j:byte;
 A:Matr;
 K:Vect;
 t:boolean;
 Sum:Integer;

Procedure Find_Equal(AFE:Matr; var KFE:Vect);
var
 b:boolean;
 p,q,m:byte;
begin
 m:=0;
 for p:=1 to N do
  begin
   b:=true;
   for q:=1 to N do
    if AFE[p,q]<>AFE[q,p] then b:=false;
   if b then
    begin
     Inc(m);
     KFE[m]:=p;
    end;
  end;
end;

Function Find_Sum(AFS:Vect):Integer;
var
 p:byte;
 S:Integer;
begin
 S:=0;
 for p:=1 to N do Inc(S,AFS[p]);
 Find_Sum:=S;
end;

Begin
 Randomize;
 for i:=1 to N do
  for j:=1 to N do
   begin
    A[i,j]:=-9+Random(10);
    if (i=5) or (j=5) then A[i,j]:=5;
    if i=7 then A[i,j]:=j;
    if j=7 then A[i,j]:=i;
   end;

 for i:=1 to N do
  begin
   for j:=1 to N do Write(A[i,j]:4);
   writeln;
  end;

 writeln;

 Find_Equal(A,K);
 if K[1]=0 then
  Writeln('No such strings and columns!')
 else
  begin
   Write('k: ');
   i:=1;
   repeat
    if K[i]>0 then
     begin
      Write(K[i]:4);
      Inc(i);
     end;
   until (K[i]=0) or (i>N);
  end;

 writeln;
 writeln;

 for i:=1 to N do
  begin
   t:=false;
   for j:=1 to N do
    if A[i,j]<0 then t:=true;
   if t then
    begin
     Sum:=Find_Sum(A[i]);
     Writeln('i = ',i,'     Sum = ',Sum:4);
    end;
  end;

 Readln;
End.
 
Во какая ошибка вылазит
 

Вложения

  • hqdefault.webp
    hqdefault.webp
    23.2 KB · Просмотры: 49
Во какая ошибка вылазит
Говорю себе мысленно: "спокойно, спокойно, надо оставаться в рамках нормативной лексики, спокойно"... Но сдерживаюсь с трудом.
Ладно, попробуйте так:
Код:
Const
 N=8;

Type
 Matr=Array[1..N,1..N] of Integer;
 Vect=Array[1..N] of Integer;

Var
 i,j:byte;
 A:Matr;
 K:Vect;
 t:boolean;
 Sum:Integer;

Procedure Find_Equal(AFE:Matr; var KFE:Vect);
var
 b:boolean;
 p,q,m:byte;
begin
 m:=0;
 for p:=1 to N do
  begin
   b:=true;
   for q:=1 to N do
    if AFE[p,q]<>AFE[q,p] then b:=false;
   if b then
    begin
     Inc(m);
     KFE[m]:=p;
    end;
  end;
end;

Function Find_Sum(AFS:Vect):Integer;
var
 p:byte;
 S:Integer;
begin
 S:=0;
 for p:=1 to N do Inc(S,AFS[p]);
 Find_Sum:=S;
end;

Begin
 Randomize;
 for i:=1 to N do
  for j:=1 to N do
   begin
    A[i,j]:=-9+Random(10);
    if (i=5) or (j=5) then A[i,j]:=5;
    if i=7 then A[i,j]:=j;
    if j=7 then A[i,j]:=i;
   end;

 for i:=1 to N do
  begin
   for j:=1 to N do Write(A[i,j]:4);
   writeln;
  end;

 writeln;

 Find_Equal(A,K);
 if K[1]=0 then
  Writeln('No such strings and columns!')
 else
  begin
   Write('k: ');
   i:=1;
   repeat
    if K[i]>0 then
     begin
      Write(K[i]:4);
      Inc(i);
     end;
   until (K[i]=0) or (i>N);
  end;

 writeln;
 writeln;

 for i:=1 to N do
  begin
   t:=false;
   for j:=1 to N do
    if A[i,j]<0 then t:=true;
   if t then
    begin
     for j:=1 to N do K[j]:=A[i,j];
     Sum:=Find_Sum(K);
     Writeln('i = ',i,'     Sum = ',Sum:4);
    end;
  end;

 Readln;
End.
 
Работает пасибо)
Владимир как обычно на высоте :D
 
Назад
Сверху