24.08.2019, 04:19 [+3 UTC]
в нашей команде: 3 779 чел. | участники онлайн: 2 (рекорд: 21)

:: РЕГИСТРАЦИЯ

задать вопрос

все разделы

правила

новости

участники

доска почёта

форум

блоги

поиск

статистика

наш журнал

наши встречи

наша галерея

отзывы о нас

поддержка

руководство

Версия системы:
7.77 (31.05.2019)
JS-v.1.34 | CSS-v.3.35

Общие новости:
28.04.2019, 09:13

Форум:
22.08.2019, 11:39

Последний вопрос:
23.08.2019, 10:58
Всего: 150135

Последний ответ:
23.08.2019, 21:59
Всего: 258866

Последняя рассылка:
24.08.2019, 01:15

Писем в очереди:
0

Мы в соцсетях:

Наша кнопка:

RFpro.ru - здесь вам помогут!

Отзывы о нас:
23.08.2009, 09:05 »
Медведева Елена Владимировна
Молодцы! Так держать!!!
02.07.2010, 07:03 »
Савенко Вадим Иванович
Спасибо, я так и думал. [вопрос № 179371, ответ № 262376]
19.03.2017, 04:43 »
svrvsvrv
Спасибо за Вашу отличную консультацию [вопрос № 190736, ответ № 274809]

РАЗДЕЛ • Pascal / Delphi / Lazarus

Создание программ на языках Pascal, Delphi и Lazarus.

[администратор рассылки: Зенченко Константин Николаевич (Старший модератор)]

Лучшие эксперты в этом разделе

Зенченко Константин Николаевич
Статус: Старший модератор
Рейтинг: 91
Асмик Гаряка
Статус: Советник
Рейтинг: 0
Орловский Дмитрий
Статус: Мастер-Эксперт
Рейтинг: 0

Перейти к консультации №:
 

Консультация онлайн # 195774
Раздел: • Pascal / Delphi / Lazarus
Автор вопроса: tanya.hryanina (Посетитель)
Отправлена: 01.06.2019, 13:18
Поступило ответов: 1

Здравствуйте! У меня возникли сложности с таким вопросом:Написать программу в Free Pascal используя динамическую процедуру GetMen. Дана матрица. Удалите из неё строку и столбец, на пересечении которых расположен минимальный элемент.


Состояние: Консультация закрыта

Ответ # 278259 от puporev (Профессионал)

Здравствуйте, tanya.hryanina!
Вообще-то такое писали в Турбо Паскале, а во Free Pascal есть нормальные динамические массивы a:array of array of integer.
Давно не писал эти getmem-freemem, вроде так. Код рабочий.

Код (Pascal) :: выделить код
uses crt;
{$R-}{отключим проверку диапазона}
const nmax=10;
type
  Tmas=^TTmas;{одна строка матрицы}
  TTmas=array[1..1] of integer;
  Tmatr=^TTmatr;{матрица-массив указателей на строки}
  TTmatr=array[1..1] of Tmas;
var
  x:Tmatr;
  n,m,k,i,j,min,imn,jmn:integer;
begin
clrscr;
randomize;
repeat
write('Количество строк от 2 до ',nmax,' m=');
readln(m);
until m in [2..nmax];
repeat
write('Количество столбцов от 2 до ',nmax,' n=');
readln(n);
until n in [2..nmax];
getmem(x,sizeof(TTmatr)*m);{выделяем память под указатели на строки}
for i:=1 to m do
getmem(x^[i],sizeof(integer)*n);{для каждой строки память для хранения данных}
writeln ('Исходная матрица X:');
for i:=1 to m do
 begin
  for j:=1 to n do
   begin
    x^[i]^[j]:=random(50);
    write(x^[i]^[j]:4);
   end;
  writeln;
 end;
min:=x^[1]^[j];
imn:=1;
jmn:=1;
for i:=1 to m do
for j:=1 to n do
if x^[i]^[j]<min then
 begin
  min:=x^[i]^[j];
  imn:=i;
  jmn:=j;
 end;
writeln('Минимальный элемент=',min,' в строке ',imn,' в столбце ',jmn);
if imn<m then
for i:=imn to m-1 do
for j:=1 to n do
x^[i]^[j]:=x^[i+1]^[j];
m:=m-1;
if jmn<n then
for j:=jmn to n-1 do
for i:=1 to m do
x^[i]^[j]:=x^[i]^[j+1];
n:=n-1;
writeln('Удаление строки ',imn,' и столбца ',jmn);
for i:=1 to m do
 begin
  for j:=1 to n do
  write(x^[i]^[j]:4);
  writeln;
 end;
write('Press Enter...');
for i:=1 to m+1 do
freemem(x^[i],sizeof(integer)*(n+1)); {освобождаем память в обратном порядке, сначала удалим строки}
freemem(x,sizeof(TTmas)*(m+1)); {потом указатели на них}
readln
end.


Консультировал: puporev (Профессионал)
Дата отправки: 01.06.2019, 14:51

Рейтинг ответа:

+2

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

Возможность оставлять сообщения в мини-форумах консультаций доступна только после входа в систему.
Воспользуйтесь кнопкой входа вверху страницы, если Вы зарегистрированы или пройдите простую процедуру регистрации на Портале.

Яндекс Rambler's Top100

главная страница | поддержка | задать вопрос

Время генерирования страницы: 0.13798 сек.

© 2001-2019, Портал RFPRO.RU, Россия
Калашников О.А.  |  Гладенюк А.Г.
Версия системы: 7.77 от 31.05.2019
Версия JS: 1.34 | Версия CSS: 3.35