Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.79/121: Рейтинг темы: голосов - 121, средняя оценка - 4.79
16 / 0 / 0
Регистрация: 26.02.2014
Сообщений: 97

Заполнить массив по спирали

05.04.2014, 13:07. Показов 25480. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Требуется заполнить массив размера N × N единичками по спирали (начиная с верхнего левого угла по часовой стрелке).


Формат входного файла

С клавиатуры вводится число N (нечетное, натуральное и не превышающее 50).


Формат выходного файла

Требуется вывести на экран построенную спираль.

ввод
7

вывод

1111111
0000001
1111101
1000101
1011101
1000001
1111111

помогите пожалуйста,реализовать её
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.04.2014, 13:07
Ответы с готовыми решениями:

Заполнить массив по спирали
По введенным значениям n, m (1 ≤ n ≤ 20, 1 ≤ m ≤ 20) заполните массив размерностью n × m числами от 1 до mn, расположив их по спирали,...

Как заполнить двумерный массив по спирали?
Как заполнить двумерный массив по спирали. 1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9 Проект у меня с...

Заполнить двухмерный массив целыми числами от 1 до 100 по спирали
Заполнить двухмерный массив целыми числами от 1 до 100 по спирали.

13
 Аватар для Metall_Version
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
05.04.2014, 13:23
Цитата Сообщение от Gaber78 Посмотреть сообщение
1111111
0000001
1111101
1000101
1011101
1000001
1111111
не пойму где тут спираль?
0
16 / 0 / 0
Регистрация: 26.02.2014
Сообщений: 97
05.04.2014, 15:10  [ТС]
Metall_Version, вот я тоже. думал может кто-то поймет
0
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
05.04.2014, 15:40
Gaber78, так вам нужно заполнить по спирали,или по примеру?

Добавлено через 1 минуту
Все,увидел спираль.Показывайте наработки,будем исправлять вместе.
0
16 / 0 / 0
Регистрация: 26.02.2014
Сообщений: 97
05.04.2014, 15:54  [ТС]
S_el,
извините,но какие могут быть наработки,если непонята задача
по примеру
0
 Аватар для Metall_Version
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
05.04.2014, 16:20
увидел спираль

❶ ❶ ❶ ❶ ❶ ❶ ❶
0 0 0 0 0 0 ❶
❶ ❶ ❶ ❶ ❶ 0 ❶
❶ 0 0 0 ❶ 0 ❶
❶ 0 ❶ ❶ ❶ 0 ❶
❶ 0 0 0 0 0 ❶
❶ ❶❶❶ ❶ ❶ ❶

Добавлено через 23 секунды
для наглядности )
ну ничего сложного. понять алгоритм построения.
0
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
05.04.2014, 16:52
Цитата Сообщение от Gaber78 Посмотреть сообщение
извините,но какие могут быть наработки,если непонята задача
по примеру
Gaber78, я хочу увидеть код,в котором нужно будет только перестроить условия в циклах.
0
 Аватар для Metall_Version
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
05.04.2014, 17:45
стало интересно придумать алгоритм )

C#
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
static void Main()
        {
            int n = Int32.Parse(Console.ReadLine());
            int[,] matr = new int[n, n];
 
            Console.WriteLine();
 
            int i, j;
                        
            for (j = 0, i = 0; j < n; j++)
                matr[i, j] = 1;
 
            for (i = 0, j = n - 1; i < n; i++)
                matr[i, j] = 1;
 
            for (j = n-1, i = n-1; j >=0; j--)
                matr[i, j] = 1;
 
            int count = 3;
            int c = 0;
 
            i= n - 1;
            j= 0;
 
            for (int x = n - 3; x > 0; x -= 2)
            {
                if (n % 2 == 0 & x == 1)
                    c = 1;
                else
                    c = 0;
 
                while (c < 2)
                {
                    switch (count)
                    {
                        case 1: //Down
                            for (int t = 0; t < x; t++)
                            {
                                i++;
                               matr[i, j] = 1;
 
                            }
 
                            count++;
                            break;
                        case 2: //Left
                            for (int t = 0; t < x; t++)
                            {
                                j--;
                                matr[i, j] = 1;
                            }
 
                            count++;
                            break;
                        case 3: //Up
                            for (int t = 0; t < x; t++)
                            {
                                i--;
                                matr[i, j] = 1;
                            }
 
                            count++;
                            break;
                        case 4: //Right
                            for (int t = 0; t < x; t++)
                            {
                                j++;
                                matr[i, j] = 1;
                            }
 
                            count = 1;
                            break;
                    }
 
 
                    c++;
                }
            }
 
          
 
            for (int ii = 0; ii < n; ii++)
            {
                for (int jj = 0; jj < n; jj++)
                    Console.Write(matr[ii, jj]);
                Console.WriteLine();
            }
 
            Console.ReadLine();
        }
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6102 / 4958 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
05.04.2014, 19:19
Metall_Version,
C#
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
using System;
 
namespace ConsoleApplication7
{
    class Program
    {
        static void Main()
        {
            const int n = 11;
            var a = GetSpire(n);
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < n; j++)
                {
                    Console.Write(a[i,j]);
                }
                Console.WriteLine();
            }
        }
 
        private static int[,] GetSpire(int n)
        {
            var result = new int[n, n];
            for (int currentChar = 1, padding = 0; padding < n/2; padding++)
            {
                for (int j = padding; j < n - padding; j++)
                    result[padding, j] = currentChar;
                for (int j = padding; j < n - padding; j++)
                    result[n - padding - 1, j] = currentChar;
                for (int i = padding + 2; i < n - padding - 1; i++)
                    result[i, padding] = currentChar;
                for (int i = padding + 1; i < n - padding - 1; i++)
                    result[i, n - padding - 1] = currentChar;
                currentChar = 1 - currentChar;
                result[padding + 1, padding] = currentChar;
            }
            return result;
        }
    }
}
0
 Аватар для Metall_Version
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
05.04.2014, 20:52
Psilon, знал что можно намного проще. но лень было минимизировать алгоритм )

кстати в вашем варианте при n=9 неверно строит матрицу

Добавлено через 3 минуты
и при других значениях 13 , 17 , 21 и тд
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6102 / 4958 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
05.04.2014, 22:02
Metall_Version, так что ли?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
        private static int[,] GetSpire(int n)
        {
            var result = new int[n, n];
            for (int currentChar = 1, padding = 0; padding < n/2; padding++)
            {
                for (int j = padding; j < n - padding; j++)
                    result[padding, j] = currentChar;
                for (int j = padding; j < n - padding; j++)
                    result[n - padding - 1, j] = currentChar;
                for (int i = padding + 2; i < n - padding - 1; i++)
                    result[i, padding] = currentChar;
                for (int i = padding + 1; i < n - padding - 1; i++)
                    result[i, n - padding - 1] = currentChar;
                currentChar = 1 - currentChar;
                result[padding + 1, padding] = currentChar;
            }
            if (n%2 != 0 && result[0, 0] == 1)
                result[n/2, n/2] = 1;
            return result;
        }
1
 Аватар для Metall_Version
2152 / 1289 / 516
Регистрация: 04.03.2014
Сообщений: 4,092
05.04.2014, 22:06
Psilon, ага . теперь работает как моя
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6102 / 4958 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
05.04.2014, 22:13
Вторая проверка лишняя, у нас всегда в [0,0] будет единица
0
54 / 71 / 20
Регистрация: 26.06.2013
Сообщений: 194
05.04.2014, 23:11
Вот еще один способ решения(правда функция rez ужасна + использование глобальных переменных)
C#
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
 public static int[,] dwig = new int[,] { { 0, 1 }, { 1, 0 }, { 0, -1 }, { -1, 0 } };
        public static int i = 0, j = 0, num = 0 ;
        public static int[,] m ;
        public static int n;
        static bool rez()
    {
        return    (i + dwig[num, 0]     < 0 || i + dwig[num, 0]      >= n ||
                   j + dwig[num, 1]     < 0 || j + dwig[num, 1]      >= n) ||
                  (i + 2 * dwig[num, 0] < n && j + 2 * dwig[num, 1]  < n &&
                   i + 2 * dwig[num, 0]>= 0 && j + 2 * dwig[num, 1]  >= 0 &&
                  (m[i + 2 * dwig[num, 0], j + 2 * dwig[num, 1]] == 1     ||
                   m[i + dwig[num, 0]+ dwig[(num + 1) % 4, 0], j + dwig[num, 1]+ dwig[(num + 1) % 4, 1]] == 1));
    }
        static void Main(string[] args)
        {
            n = Convert.ToInt32(Console.ReadLine());
            m = new int[n, n]; 
            while(true )
            { 
                m[i, j] = 1;
                if (rez())
                {
                    num = (num + 1) % 4;
                    if (rez() ) break;
                }
                else
                {
                    i += dwig[num, 0];
                    j += dwig[num, 1];
                } 
            } 
            for (i=0;i<n;i++)
            {
                for (j = 0; j < n; j++) Console.Write(m[i, j] + " ");
                Console.WriteLine();
            }
        }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.04.2014, 23:11
Помогаю со студенческими работами здесь

Заполнить двумерный массив произвольного размера последовательными числами по спирали
Здравствуйте! Нужна ваша помощь. Прошу, код должен быть предельно простым. Заполнить двумерный массив произвольного размера...

Заполнить двумерный массив цифрами по спирали, против часовой стрелки
Доброго времени суток. Вот задание : Заполнить двумерный массив цифрами по спирали, против часовой стрелки. Вот решение: ...

Заполнить двумерный массив указанного размера последовательными натуральными числами, двигаясь от верхнего левого элемента вправо и далее по спирали
Заполнить двумерный массив указанного размера последовательными натуральными числами, двигаясь от верхнего левого элемента вправо и далее...

Заполнить матрицу по спирали
Помогите переписать код на C#, пожалуйста Условие: Улитка. Матрицу М(m, n) заполнить натуральными числами от 1 до m×n по...

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


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru