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

Заполнение матрицы спиралью

17.09.2019, 18:31. Показов 2660. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Как можно реализовать такое заполнение матрицы:

1 3 4 9 10
2 5 8 11 14
6 7 12 13 15

То есть должна заполнятся от левого верхнего угла по диагоналям
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.09.2019, 18:31
Ответы с готовыми решениями:

Заполнение двухмерного массива спиралью
Составить программу которая заполняет квадратную матрицу порядка n натуральными числами 1,2,3....{n}^{2}, записывая их в нее "по...

Заполнение массива 5*5 спиралью
Можете досконально объяснить как заполнить массив 5*5 спиралью???

Заполнение матрицы спиралью
Доброго времени суток На входе - N, на выходе - матрица NxN, заполненная спиралью(см. пример). input.txt - 5 output.txt: 1 2 3 4...

9
 Аватар для Sun Serega
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
17.09.2019, 21:04
Это не спирально. Спирально это:
01 02 03 04 05
12 13 14 15 06
11 10 09 08 07
0
 Аватар для mr-Crocodile
3053 / 1672 / 657
Регистрация: 19.03.2019
Сообщений: 5,381
18.09.2019, 12:04
на с++
Заполнить массив змейкой по диагонали

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
program zmeika;
const n=3; m=5;
var a:array[0..n-1,0..m-1] of integer;
 c,z, k, i, j : integer;
begin
(*
for (z = 0; z < m + n - 1;++z)
{
    if (k==0) { if (z < n) {i = z; j = 0;} else {i= n-1; j= z-n+1;}}
        else  { if (z < m) {j = z; i = 0;} else {j= m-1; i= z-m+1;}}
 
    if (k==0)  while ( (j>=0 ) && ( i>=0)  && ( j<m) ) { a[i--][j++]= ++c; k=1;}
        else   while ( (j>=0 ) && ( i< n )  )          { a[i++][j--]= ++c; k=0;}
}
*)
c:=0;
k:=1;
for z := 0 to m + n - 1 do
begin
    if (k=0) then begin  if (z < n) then begin i := z; j := 0 end else begin i:= n-1; j:= z-n+1 end end
        else  begin if (z < m) then begin j := z; i := 0 end else begin j:= m-1; i:= z-m+1 end end;
 
    if (k=0) then  while ( (j>=0 ) and ( i>=0)  and ( j<m) ) do begin Inc(c); a[i][j] := c; Dec(i); Inc(j); k:=1; end
        else   while ( (j>=0 ) and ( i< n )  ) do begin Inc(c); a[i][j] := c; Inc(i); Dec(j); k:=0; end
end;
 
for i:=0 to n-1 do begin
  for j:= 0 to m-1 do Write(a[i,j]:4);
  WriteLn;
end;
 
end.
1
0 / 0 / 0
Регистрация: 10.09.2019
Сообщений: 20
24.09.2019, 07:11  [ТС]
спасибо, вроде работает правильно.
Только это pascal, а не c++ )) Но все равно спасибо, мне на паскале и нужно было
0
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
24.09.2019, 07:29
На С++ код по ссылке.
0
 Аватар для mr-Crocodile
3053 / 1672 / 657
Регистрация: 19.03.2019
Сообщений: 5,381
24.09.2019, 10:20
Цитата Сообщение от mihtere Посмотреть сообщение
Только это pascal, а не c++ )) Но все равно спасибо, мне на паскале и нужно было
так я вижу, что раз ты в теме Паскаля, значит, тебе на Паскаль нужно.
вот я взял код по ссылке, там он был на C++ (можешь на ссылку выше нажать, посмотреть).
я его по быстрому, ничего не меняя в алгоритме и переписал.
а то, что он работает - это заслуга marat_miaki.
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
24.09.2019, 11:31
mr-Crocodile,
Ошибка у вас при переводе (в строке 18) или в оригинале?
C++
7
for (z = 0; z < m+n-1; ++z)
эквивалентно
Pascal
18
for z:=0 to m+n-2 do
1
 Аватар для mr-Crocodile
3053 / 1672 / 657
Регистрация: 19.03.2019
Сообщений: 5,381
24.09.2019, 11:46
Цитата Сообщение от bormant Посмотреть сообщение
Ошибка у вас при переводе (в строке 18) или в оригинале?
у меня однозначно ошибка при переводе.

а как правильно - я не знаю
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
24.09.2019, 11:52
Лучший ответ Сообщение было отмечено mihtere как решение

Решение

В сухом остатке:
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
const n=3; m=5;
var
  a: array [0..n-1, 0..m-1] of Integer;
  c, z, k, i, j: Integer;
begin
  c:=0; k:=1;
  for z:=0 to m+n-2 do begin
    if k=0 then begin
      if z<n
      then begin i:=z;   j:=0;     end
      else begin i:=n-1; j:=z-n+1; end;
      while (i>=0) and (j<m) do begin
        Inc(c); a[i,j]:=c; Dec(i); Inc(j);
      end; 
      k:=1;
    end else begin
      if z<m
      then begin j:=z;   i:=0;     end
      else begin j:=m-1; i:=z-m+1; end;
      while (j>=0) and (i<n) do begin
        Inc(c); a[i,j]:=c; Inc(i); Dec(j);
      end;
      k:=0;
    end;
  end;
  for i:=0 to n-1 do begin
    for j:=0 to m-1 do Write(a[i,j] :4); WriteLn;
  end;
end.
2
 Аватар для mr-Crocodile
3053 / 1672 / 657
Регистрация: 19.03.2019
Сообщений: 5,381
24.09.2019, 15:40
Цитата Сообщение от bormant Посмотреть сообщение
В сухом остатке:
Супер!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.09.2019, 15:40
Помогаю со студенческими работами здесь

Заполнение матрицы спиралью
Здравствуйте! Я знаю, что на форуме есть ответ на данный вопрос, но не понятно, как происходит само заполнение. Не понятно для чего...

Заполнение матрицы спиралью - корректировка кода
Код вроде работает,но не хочет заполняться в консольке по спирали. Можете исправить эту маленькую проблему? #include...

Заполнение матрицы спиралью против часовой стрелки
Напишите программу, которая выводит на экран матрицу размера N*N (0&lt;N&lt;100) заполненную змейкой числами от 1 до N^2 по следующему образцу...

Заполнение массива двойной спиралью
Дано число N, вывести массив по двойной спирали из нулей и единиц по часовой стрелке Input: 7 Output: 1111111 0000001 1111101 ...

Двумерный массив, заполнение спиралью
Вечер добрый. Нужна немного помощь по коду и хотя бы простое объяснение по нему же. Пытаюсь воткнуть ввод переменной &quot;n&quot; с...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru