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

Составить программу заполнения данной матрицы и смещения элементов в данной матрице против часовой стрелки по спирали

20.05.2020, 09:25. Показов 592. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дана квадратная матрица N*N. 3<=N<=11 – нечётное, задаётся пользователем. Матрица заполняется программой целыми числами согласно рисунку (заполнение массива вручную не допустимо как на этапе разработки, так и на этапе выполнения программы).

Требуется составить программу заполнения данной матрицы и смещения элементов в данной матрице против часовой стрелки по спирали.


Рисунок 1 во вложении(Как нужно получить). Результат выполнения работы программы при N=5



Исходную и результирующую матрицу выводить на экран.

То, что у нас получилось:

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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
const n = 5;
m = 5;
var a:array[1..n,1..m] of real;
  c,d,i,j,b,f,g,k:integer;
function rigth(k:integer):integer;
  var i,j:integer;
  begin
    for i:= k to k do
      begin
        for j:= k to m-i+1 do
          begin
            inc(c);
            a[i,j]:=c;
          end;
      end;
  end;
function donw(k:integer):integer;
  var i,j:integer;
  begin
    for j:= m-k+1 to m-k+1 do
      begin
        for i:= k+1 to n-k+1 do 
          begin
            inc(c);
            a[i,j]:=c;
          end;
      end;
  end;
function left(k:integer):integer;
  var i,j:integer;
  begin
    for i:= n-k+1 to n-k+1 do
      begin
        for j:= m-k downto k do 
          begin
            inc(c);
            a[i,j]:=c;
          end;
      end;
  end;
function up(k:integer):integer;
  var i,j:integer;
  begin
    for j:= k to k do
      begin
        for i:= n-k downto k+1 do 
          begin
            inc(c);
            a[i,j]:=c;
          end;
      end;
  end;
begin
  k:=1;
  repeat
  rigth(k);
  donw(k);
  left(k);
  up(k);
  inc(k);
  until(k=n+2);
  for i:= 1 to n do 
    begin
      for j:= 1 to m do
        begin
            begin
            end;
          write(a[i,j]:5);
        end;
      writeln;
      c:=0;
    end;
end.
Изображения
 
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.05.2020, 09:25
Ответы с готовыми решениями:

Переделать задание на PascalABC
uses crt; const n=10; type sport=1..6; sportgroup=set of sport; group=array of sportgroup; ( Помогите исправить кто может, мне...

Задание на массив и задание на матрицу.
1.Удалить из массива A(n) нулевые элементы, передвигая на их место следующие элементы, не нарушая порядка их следования. В результате...

График температур. Подправить код из turbo (не знаю где писать в PascalABC или PascalABC.net)
На Pascal ABC не запускается(( uses crt,graph; const n=31; {массив - константа, можно ввести с клавиатуры} ...

2
6 / 4 / 2
Регистрация: 19.05.2020
Сообщений: 8
20.05.2020, 21:02
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
const
  sz = 11;
 
type
  Matrix = array[1..sz, 1..sz] of integer;
 
var
  A: Matrix;
  n: integer;
 
procedure EnterMatrixSize(var n: integer; var A: Matrix);
begin
  repeat
    n := ReadInteger('Введите количество строк и столбцов: ');
    if (n mod 2 = 0) or (n <= 1) or (n > 11) then
      Println('Ошибка повторите ввод: ');
  until (n mod 2 <> 0) and (n > 1) and (n < 11);
  begin
    for var i := 1 to n do
      for var j := 1 to n do
        A[i, j] := 0;
  end;
end;
 
procedure GenerateMatrix(n: integer; var A: Matrix);
var
  m1, m2: integer;
var
  k := 1;
begin
  m1 := 1;
  m2 := n;
  repeat
    for var j := m1 to m2 do
    begin
      var i := m1;
      A[i, j] := k;
      k += 1;   
    end;
    for var i := m1 + 1 to m2 do
    begin
      var j := m2;
      A[i, j] := k;
      k += 1;     
    end;
    for var j := m2 - 1 downto m1 do
    begin
      var i := m2;
      A[i, j] := k;
      k += 1;
    end;
    for var i := m2 - 1 downto m1 + 1 do
    begin
      var j := m1;
      A[i, j] := k;
      k += 1;
    end;
    m1 += 1;
    m2 -= 1;
  until k = sqr(n)+1;
  for var i := 1 to n do 
    begin
      for var j := 1 to n do 
        write(A[i, j] : 4);
      writeln;
      end;
      Writeln;
end;
procedure offset(n: integer; var A: Matrix);
var
  m1, m2, x0: integer;
var
  k := 1;
begin
  x0 := (n div 2) + 1;
  m1 := 1;
  m2 := n;
  repeat
    for var j := m1 to m2 do
    begin
      var i := m1;
      A[i, j] := k+1;
      k += 1;   
    end;
    for var i := m1 + 1 to m2 do
    begin
      var j := m2;
      A[i, j] := k+1;
      k += 1;     
    end;
    for var j := m2 - 1 downto m1 do
    begin
      var i := m2;
      A[i, j] := k+1;
      k += 1;
    end;
    for var i := m2 - 1 downto m1 + 1 do
    begin
      var j := m1;
      A[i, j] := k+1;
      k += 1;
    end;
    m1 += 1;
    m2 -= 1;
  until k = sqr(n)+1;
  A[x0,x0]:=1;
  for var i := 1 to n do 
    begin
      for var j := 1 to n do 
        write(A[i, j] : 4);
      writeln;
      end;
end;
begin
  EnterMatrixSize(n, A);
  GenerateMatrix(n, A);
  Offset(n,A);
end.
0
 Аватар для canadamoscow
1179 / 430 / 194
Регистрация: 23.03.2020
Сообщений: 1,021
Записей в блоге: 1
01.07.2020, 11:22
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
begin
  var n:= ReadInteger('n ='); 
  var Матрица := new integer[n,n];
  var a := Range(1, n*n).toArray;
  loop 2 do begin
   var (i, j, ii, jj) := (0, -1, 1, 1);
   var (путь, ряд, вРяду, повторРяда) := (false, n, 0, false);
   for var Элемент := 0 to n*n-1 do
    begin
     if Путь then i+= ii else  j += jj;
     Матрица[i, j]:= a[Элемент]; 
     inc(Вряду);
     if Вряду = ряд then 
       begin 
         if ПовторРяда then ii := -ii else (jj, ряд) := (-jj, ряд -1);
         (Вряду,  повторРяда, путь) := (0, not(повторРяда), not(путь))
       end;
   end;
  Матрица.Println;  Println;
  a := (a[1:] + a[0]).toArray;
  end;
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.07.2020, 11:22
Помогаю со студенческими работами здесь

Задание на целочисленную матрицу
Задание: Среди строк заданной целочисленной матрицы, найдите строку с максимальной суммой модулей элементов. ЗЫ Надо чтобы программист...

Где можно скачать PascalABC а не PascalABC.Net
Где можно скачать PascalABC а не PascalABC.Net?

В чем разница PascalABC.net и PascalABC
Скажите в чем разница PascalABC.net И PascalABC. Помню когда-то давно программы работающие в PascalABC у меня не работали в .net

Вывод дописать, если не сложно) Задание:Построить квадратную матрицу порядка 2n!
#include &lt;iostream&gt; #include &lt;stdlib.h&gt; #include &lt;cstdio&gt; using namespace std; int element(int x,int y, int rang, int *point)...

задание по паскалю Сформировать квадратную матрицу порядка n (где n – четное число) по заданному образцу
Сформировать квадратную матрицу порядка n (где n – четное число) по заданному образцу 1 1 1 .. 1 1 1 1 0 0 .. 0 0 1 1 0 0 .. 0 0...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача №1: при указании работ (справочник РаботыПоРемонтуСпецтехники),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru