0 / 0 / 0
Регистрация: 31.10.2017
Сообщений: 4

Заполнить матрицу n на n по спирали

31.10.2017, 10:05. Показов 2474. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание : Заполнить матрицу n на n следующим образом (пустые клетки заполняются 0)

Название: image0022.png
Просмотров: 37

Размер: 1.2 Кб

Не могу додумать код. Знающие люди подскажите, пожалуйста.

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
const n1=15;
var a:array [1..n1,1..n1] of integer;
    i,j,n,imax,jmax,imin,jmin,k:integer;
begin
 write('n=');readln(n);
 if (n<=0) or (n>n1) then writeln('Число ',n,' должно быть большее, чем 0 и меньшее, чем 16')
 else
 begin
 
  k:=0;
  imax:=(n div 2)+1;
  jmax:=(n div 2)+1;
  imin:=(n div 2)+1;
  jmin:=(n div 2);
  repeat
   for i:=imax downto imin do
    a[i,jmax]:=1;
   k:=k+1;
   imin:=imax-k;
   for j:=jmax downto jmin do
    a[imin,j]:=1;
   k:=k+1;
   jmin:=jmax-k;
   imax:=imin+k;
   for i:=imin to imax do
    a[i,jmin]:=1;
   k:=k+1;
   imax:=imin+k;
   jmax:=jmin+k;
   for j:=jmin to jmax do
    a[imax,j]:=1;
   k:=k+1;
  until k=n;
  
  for i:=1 to n do
  begin
   for j:=1 to n do
    write(a[i,j],' ');
   writeln();
  end;
 end;
end.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.10.2017, 10:05
Ответы с готовыми решениями:

Заполнить матрицу по спирали.
http://************.com/files/4x9alup5f вот ссылка на рисунок по которому заполняется матрица!!! ПАЖАЛУСТО ОЧ НУЖНО САМ НУ НЕ КАК НЕ МОГУ...

Заполнить матрицу по спирали.
Добрый вечер. Нужно составить массив 7х7 из чисел от 1 до 49, вот такой. 1 2 3 4 5 6 7 24 25 26 27 28 29 8 23 40 41 42 43 30 9 ...

Заполнить квадратную матрицу единицами по спирали
Помогите решить, пожалуйста!!!=-O Заполнить квадратную матрицу NxN единицами ('1') по спирали (начиная с элемента с координатами...

4
Почетный модератор
 Аватар для Puporev
64312 / 47609 / 32742
Регистрация: 18.05.2008
Сообщений: 115,181
31.10.2017, 12:41
Есть много способов, предлагаю такой.
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
const n1=20;
var a:array [1..n1,1..n1] of integer;
    i,j,n,k,p:integer;
begin
repeat
write('Введите размер массива от 3 до 20 n=');
readln(n);
until n in [3..20];
for i:=1 to n do
for j:=1 to n do
a[i,j]:=0;
k:=0;
i:=0;
j:=n;
for p:=1 to (n+3)div 4 do
 begin
  //вниз
  while i<n-k do
   begin
    inc(i);
    a[i,j]:=1;
   end;
  //влево
  while j>1+k do
   begin
    dec(j);
    a[i,j]:=1;
   end;
  inc(k);
  //вверх
  while i>k+1 do
   begin
    dec(i);
    a[i,j]:=1;
   end;
  inc(k);
  //вправо
  while j<n-k do
   begin
    inc(j);
    a[i,j]:=1;
   end;
 end;
for i:=1 to n do
 begin
  for j:=1 to n do
  write(a[i,j]:2);
  writeln;
 end;
end.
1
0 / 0 / 0
Регистрация: 31.10.2017
Сообщений: 4
01.11.2017, 18:38  [ТС]
Да, забыл уточнить, что матрица заполняется от центра, т.е. (n div 2)+1, против часовой стрелки.
0
Почетный модератор
 Аватар для Puporev
64312 / 47609 / 32742
Регистрация: 18.05.2008
Сообщений: 115,181
02.11.2017, 09:01
Лучший ответ Сообщение было отмечено ZX Spectrum-128 как решение

Решение

Можно так.
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
54
55
56
57
const n1=15;
var a:array [1..n1,1..n1] of integer;
    i,j,n,k,p,f:integer;
begin
repeat
write('Введите размер массива от 3 до 15 n=');
readln(n);
until n in [3..15];
for i:=1 to n do
for j:=1 to n do
a[i,j]:=0;
i:=n div 2+1;
j:=n div 2+1;
a[i,j]:=1;
k:=0;//длина перемещения в 1 направлении
f:=0; //фиксация выхода из программы
repeat
inc(k);
p:=0;//счетчик ходов в 1 направлени
while(p<k)and(f=0) do //вверх
 begin
  dec(i);
  inc(p);
  if i>=1 then a[i,j]:=1 else  f:=1;
 end;
inc(k);
p:=0;
while(p<k)and(f=0) do //влево
 begin
  dec(j);
  inc(p);
  if j>=1 then a[i,j]:=1 else  f:=1;
 end;
inc(k);
p:=0;
while(p<k)and(f=0) do //вниз
 begin
  inc(i);
  inc(p);
  if i<=n then a[i,j]:=1 else f:=1;
 end;
inc(k);
p:=0;
while(p<k)and(f=0) do //вправо
 begin
  inc(j);
  inc(p);
  if j<=n then a[i,j]:=1 else f:=1;
 end;
until f=1;
for i:=1 to n do
 begin
  for j:=1 to n do
  write(a[i,j]:2);
  writeln;
 end;
end.
1
0 / 0 / 0
Регистрация: 31.10.2017
Сообщений: 4
05.11.2017, 13:03  [ТС]
Спасибо за помощь
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.11.2017, 13:03
Помогаю со студенческими работами здесь

Заполнить матрицу числами от единицы до n^2 по спирали
Выведите двумерный массив, размерами N×N, заполненный числами от единицы до N2 по спирали. Числовая спираль начинается в левом верхнем углу...

Заполнить квадратную матрицу натуральными числами по спирали
составить программу,которая заполняет квадратную матрицу порядка n нутуральными числами 1,2,3,...n,записывая их в нее &quot;по...

Заполнить матрицу от центра по спирали: вниз - влево - вверх - вправо
Заполнить матрицу ЛП, от центра по спирали: вниз - влево - вверх - вправо.

Заполнить матрицу от левого верхнего угла по спирали: вниз-вправо-вверх-влево
Заполнить матрицу ЛП, от левого верхнего угла по спирали: вниз-вправо-вверх-влево Сама матрица: 1323102928272625 23356555453525124...

Прямоугольную матрицу заполнить последовательными чётными натуральными числами "по спирали" .
а) составить блок-схему алгоритма решения; б) написать реализующую алгоритм программу на языке Pascal Данную прямоугольную...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

Новые блоги и статьи
Мастер-класс по микросервисам на Node.js
Reangularity 21.06.2025
Node. js стал одной из самых популярных платформ для микросервисной архитектуры не случайно. Его неблокирующая однопоточная модель и событийно-ориентированный подход делают его идеальным для. . .
Управление Arduino из WPF приложения
Wired 21.06.2025
Зачем вообще связывать Arduino с WPF-приложением? Казалось бы, у Arduino есть собственная среда разработки, своя экосистема, свои способы управления. Однако при создании серьезных проектов. . .
Звёздная пыль
kumehtar 20.06.2025
Я просто это себе представляю: как создавался этот мир. Как энергия слипалась в маленькие частички. Как они собирались в первые звёзды, как во вселенной впервые появился Свет. Как эти звёзды. . .
Создание нейросети с PyTorch
AI_Generated 19.06.2025
Ключевое преимущество PyTorch — его питоновская натура. В отличие от TensorFlow, который изначально был построен как статический вычислительный граф, PyTorch предлагает динамический подход. Это. . .
JWT аутентификация в ASP.NET Core
UnmanagedCoder 18.06.2025
Разрабатывая веб-приложения, я постоянно сталкиваюсь с дилеммой: как обеспечить надежную аутентификацию пользователей без ущерба для производительности и масштабируемости? Классические подходы на. . .
Краткий курс по С#
aaLeXAA 18.06.2025
Здесь вы найдете все необходимые функции чтоб написать програму на C# Задание 1: КЛАСС FORM 1 public partial class Form1 : Form { Spisok listin = new Spisok(); . . .
50 самых полезных примеров кода Python для частых задач
py-thonny 17.06.2025
Эффективность работы разработчика часто измеряется не количеством написаных строк, а скоростью решения задач. Готовые сниппеты значительно ускоряют разработку, помогают избежать типичных ошибок и. . .
C# и продвинутые приемы работы с БД
stackOverflow 17.06.2025
Каждый . NET разработчик рано или поздно сталкивается с ситуацией, когда привычные методы работы с базами данных превращаются в источник бессонных ночей. Я сам неоднократно попадал в такие ситуации,. . .
Angular: Вопросы и ответы на собеседовании
Reangularity 15.06.2025
Готовишься к техническому интервью по Angular? Я собрал самые распространенные вопросы, с которыми сталкиваются разработчики на собеседованиях в этом году. От базовых концепций до продвинутых. . .
Архитектура Onion в ASP.NET Core MVC
stackOverflow 15.06.2025
Что такое эта "луковая" архитектура? Термин предложил Джеффри Палермо (Jeffrey Palermo) в 2008 году, и с тех пор подход только набирал обороты. Суть проста - представьте себе лук с его. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru