Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 06.10.2015
Сообщений: 48

Построить новую матрицу такого же размера по правилу

17.10.2015, 13:26. Показов 1168. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Вот полностью программа и по факту должна работать,но где-то здесь if a[i1,j1] < min then
min := a[i1,j1]; b[i,j] := min; выдаёт ошибку выход за границу массива,помогите найти ошибку

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
{Дана прямоугольная целоичесленная матрица размером m x n. 
Построить новую матрицу такого же размера,гд каждый элемент 
равен минимальному срерди соседей соответсующего элемента 
сходной матрицы} 
program P1; 
const 
 m = 4; 
 n = 5; 
type 
 Matrix = array [1..m, 1..n] of integer; 
var 
 a, b : Matrix; 
 i, j, i1, j1 : integer; 
 min : integer; 
begin 
 {Заполнение матрицы а случайными} 
 randomize; 
 for i := 1 to m do 
 for j := 1 to n do 
 a[i,j] := random(20); 
 {Вывод матрицы а на экран} 
 writeln('Матрица а:'); 
 for i := 1 to m do 
 begin 
 for j := 1 to n do 
 write(a[i,j]:4); 
 writeln; 
 end; 
 {Построение матрицы b - минимумы среди соседей} 
 for i := 1 to m do 
 for j := 1 to n do 
 begin 
 {Поиск минимального значения среди соседей 
 элемента а[i,j]} 
 min := MaxInt; //-Максимальное возможное среди значений типа integer 
 for i1 := i-1 to i+1 do 
 for j1 := j-1 to j+1 do 
 if ((1 <= i1) and (i1 <= m)) or //проверка,чтобы новый масив 
 ((1 <= j1) and (j1 <= n)) and // не выходил за пределы изначального 
 (i <> i1) and (j <> j1) then // массива 
 if a[i1,j1] < min then 
 min := a[i1,j1]; 
 b[i,j] := min; 
 end; 
 {Вывод матрицы b на экран} 
 writeln('Матрица b:'); 
 for i := 1 to m do 
 begin 
 for j := 1 to n do 
 write(b[i,j]:4); 
 writeln; 
 end; 
end.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.10.2015, 13:26
Ответы с готовыми решениями:

Построить матрицу по правилу
Данна целочисленная матрица размером n * m. Написать программу, которая формирует двумерный массив по следующему правилу: элементы первой...

Построить матрицу по правилу
сформировать квадратную матрицу порядка n по заданному образцу

Построить квадратную матрицу по правилу
построить квадратную матрицу порядка n 100001 020020 003300 004400 050050 600006

3
Платежеспособный зверь
 Аватар для кот Бегемот
8959 / 4384 / 1652
Регистрация: 28.10.2009
Сообщений: 11,629
17.10.2015, 13:56
В комментах замени // на {}
в строке 38 не or а and по-моему
Но прога всё равно не то выдаёт
потому, что проверяются не 4 соседа, а 8
0
Почетный модератор
 Аватар для Puporev
64311 / 47608 / 32742
Регистрация: 18.05.2008
Сообщений: 115,181
17.10.2015, 15:29
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Цитата Сообщение от кот Бегемот Посмотреть сообщение
В комментах замени // на {}
Зачем? Это же АВС.
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
const
 m = 4;
 n = 5;
type
 Matrix = array [0..m+1, 0..n+1] of integer;
var
 a, b : Matrix;
 i, j, i1, j1 : integer;
 min : integer;
begin
 randomize;
 //создадим периметр из маесимальных чисел
 for i:=0 to n+1 do
  begin
   a[0,i]:=maxint;
   a[m+1,i]:=maxint;
  end;
for i:=0 to m+1 do
  begin
   a[i,0]:=maxint;
   a[i,n+1]:=maxint;
  end;
 //заполним середину
 writeln('Матрица а:');
 for i:=1 to m do
  begin
   for j:=1 to n do
    begin
     a[i,j] := random(20);
     write(a[i,j]:4);
    end;
   writeln;
 end;
 {Построение матрицы b - минимумы среди соседей}
 for i:=1 to m do
 for j:=1 to n do
  begin
   min:=a[i-1,j-1];
   for i1:=i-1 to i+1 do
   for j1:=j-1 to j+1 do
   if ((i1<>i) or (j1<>j))and(a[i1,j1]<min) then  min:=a[i1,j1];
   b[i,j]:=min;
  end;
 {Вывод матрицы b на экран}
 writeln('Матрица b:');
 for i:=1 to m do
  begin
   for j:=1 to n do
   write(b[i,j]:4);
   writeln;
  end;
end.
1
Платежеспособный зверь
 Аватар для кот Бегемот
8959 / 4384 / 1652
Регистрация: 28.10.2009
Сообщений: 11,629
17.10.2015, 18:23
Я в ТурбоПаскале проверял. Но у меня что-то и в ABC заглючило.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.10.2015, 18:23
Помогаю со студенческими работами здесь

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

Получить новую матрицу того же размера по правилу
Даны две действительные квадратные матрицы размером n =&lt; 7. Получить новую матрицу того же размера путем добавления к элементам каждого...

Получить новую матрицу того же размера по правилу
Даны две действительные квадратные матрицы размером n =&lt; 7. Получить новую матрицу того же размера путем добавления к элементам каждого...

Построить матрицу В такого же размера, как А, элементы которой обладают заданным свойством
Построить матрицу В такого же размера, как А, элементы которой обладают следующим свойством: элемент В равен максимальному из элементов...

Получить массив В, такого же размера как и А, по правилу
Создать одномерный массив А размером N, компоненты которого являются случайными целыми числами от -20 до 20. Получить массив В, такого же...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Работа с объемным DOM в javascript
Htext 04.04.2025
Сегодня прочитал статью тут о расходах памяти в JS, ее утечках и т. п. И вот что вспомнил из своей недавней практики. Может, кому пригодится. Хотя, в той статье об этом тоже есть. Дело в том, что я. . .
Оптимизация производительности Node.js с помощью кластеризации
run.dev 04.04.2025
Масштабирование приложений для обработки тысяч и миллионов запросов — обыденная задача для многих команд. Node. js, благодаря своей асинхронной событийно-ориентированной архитектуре, стал популярной. . .
Управление зависимостями в Python с Poetry
py-thonny 04.04.2025
Стандартный инструмент для установки пакетов в Python - pip - прекрасно справляется с базовыми сценариями: установил пакет командой pip install и используешь его. Но что произойдёт, когда разные. . .
Мониторинг с Prometheus в PHP
Jason-Webb 04.04.2025
Prometheus выделяется среди других систем мониторинга своим подходом к сбору и хранению метрик. В отличие от New Relic, который использует агентный подход и отправляет данные во внешнее хранилище,. . .
Пакет Context в Golang: Управление потоками и ресурсами
golander 04.04.2025
Работа с горутинами в Go часто напоминает управление непослушными детьми - они разбегаются кто куда, делают что хотят и не всегда завершаются вовремя. К счастью, в Go 1. 7 появился пакет context,. . .
Контейнеризация React приложений с Docker
Reangularity 03.04.2025
Контейнеризация позволяет упаковать приложение со всеми его зависимостями в автономный контейнер, который можно запустить на любой платформе с установленным Docker. Это существенно упрощает процессы. . .
Свой попап в SwiftUI
mobDevWorks 03.04.2025
SwiftUI, как декларативный фреймворк от Apple, предоставляет множество инструментов для создания пользовательских интерфейсов. В нашем распоряжении есть такие API как alerts, popovers, action sheets. . .
Антипаттерны микросервисной архитектуры
ArchitectMsa 03.04.2025
Хорошо спроектированная микросервисная система может выдержать испытание временем, оставаясь гибкой, масштабируемой и устойчивой к большинству проблем. Такая архитектура обладает высоким уровнем. . .
std::mutex в C++: Советы и примеры использования
bytestream 03.04.2025
std::mutex - это механизм взаимного исключения, который гарантирует, что критический участок кода выполняется только одним потоком в каждый момент времени. Это простое, но могущественное средство. . .
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер