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

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

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

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

Проблема с задачами по Паскалю

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

Smolny

Ученик
Регистрация
26 Дек 2016
Сообщения
1
Реакции
0
Баллы
0
Проблема с задачами по Паскалю

Дана матрица M*N. Найти сумму среди положительных и четных элементов в каждой строке с записью в оперативную память. Задание переписано дословно из лабораторной работы, помогите пожалкйста
 
Ну и в чём проблема? Если "с записью в оперативную память", то, очевидно, потребуется одномерный массив размерностью M для хранения суммы. Пройтись по матрице от 1 до M, для каждой строки перебрать все элементы от 1 до N и если он положительный и чётный, то в сумму для этой строки его добавить.
 
Ну и в чём проблема? Если "с записью в оперативную память", то, очевидно, потребуется одномерный массив размерностью M для хранения суммы.
Ох, боюсь тут не так просто. Скорее всего, "с записью в оперативную память" означает использование динамических переменных и указателей. Вообще-то я в этом не очень, но ладно, после обеда, если будет время, попробую.
 
Как-то так:
Код:
{$r-}
Const
 M=10;
 N=12;

Type
 T=Array[1..1] of Integer;

Var
 A,V:^T;
 D:^Integer;
 i,j:Integer;

Begin
 GetMem(A, SizeOf(Integer)*M*N);
 GetMem(V, SizeOf(Integer)*M);
 GetMem(D, SizeOf(Integer));

 Randomize;

 WriteLn('Matrix A:');
 for i:=1 to M do
  for j:=1 to N do
   A^[N*(i-1)+j]:=-10+Random(20);

 for i:=1 to M do
  begin
   for j:=1 to N do
    Write(A^[N*(i-1)+j]:5);
   WriteLn;
  end;
 WriteLn;
 Writeln;

 for i:=1 to M do
  begin
   New(D);
   D^:=0;
   for j:=1 to N do
    if (A^[N*(i-1)+j]>0) and ((A^[N*(i-1)+j] mod 2)=0) then D^:=D^+A^[N*(i-1)+j];
   V^[i]:=D^;
   Dispose(D);
  end;

 Writeln('Sums:');
 for i:=1 to M do Write(V^[i]:5);

 FreeMem(A, SizeOf(Integer)*M*N);
 FreeMem(V, SizeOf(Integer)*M);

 ReadLn;
END.
 
Назад
Сверху