Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.88/41: Рейтинг темы: голосов - 41, средняя оценка - 4.88
Attractive_girl
0 / 0 / 0
Регистрация: 01.11.2009
Сообщений: 3
1

Обход матрицы по спирали

01.11.2009, 23:50. Просмотров 7625. Ответов 4
Метки нет (Все метки)

Пожалуйста, подскажите как должен выглядеть листинг к такой программе!?
Обойти по спирали, начиная с центра, все элементы квадратной матрицы 15х15. Порядок обхода - против часовой стрелки. Вывести на печать элементы матрицы в порядке обхода.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.11.2009, 23:50
Ответы с готовыми решениями:

Выполнить обход матрицы по спирали
Здійснити обхід матриці по спіралі за годинниковою стрілкою, починаючи від ЇЇ...

Указатель на функцию и обход матрицы по спирали
Всем привет, впервые столкнулся с такой задачей, не могли бы помочь с решением?...

Требуется совершить обход квадратной матрицы по спирали
помогите с этой задачкой )) Спираль (Время: 1 сек. Память: 16 Мб...

Заполнение матрицы по спирали
Напишите программу, которая заполняет матрицу из N строк и M столбцов...

Заполнение матрицы по спирали
Привет всем, можете помочь пожалуйста: надо придумать алгоритм, написать код на...

4
valeriikozlov
Эксперт С++
4687 / 2513 / 751
Регистрация: 18.08.2009
Сообщений: 4,550
02.11.2009, 11:00 2
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
#include <stdlib.h> 
#include <time.h> 
int main() 
{
        int  i, j, mas[15][15], i1, j1, mas1[15*15], temp=0;
                srand(time(NULL));
                for(i=0; i<15; i++)
                        for(j=0; j<15; j++)
                                mas[i][j]=rand()%(51);
                printf("Ishodny massiv:\n");
                        for(i=0; i<15; i++)
                        {
                                for(j=0; j<15; j++)
                                        printf("%5d",mas[i][j]);
                                printf("\n");
                        }
                printf("Elementy massiva po usloviu:\n");
                i1=j1=15;
                j=0;
                while(j<j1)
                {
                    i=15-i1;
                    j=15-j1;
                for(; j<j1; j++)
                {
                    mas1[temp]=mas[i][j];
                    temp++;
                }
                j--;
                for(i++; i<i1; i++)
                {
                    mas1[temp]=mas[i][j];
                    temp++;
                }
                i--;
                for(j--; j>=15-j1; j--)
                {
                    mas1[temp]=mas[i][j];
                    temp++;
                }
                j++;
                for(i--; i>15-j1; i--)
                {
                    mas1[temp]=mas[i][j];
                    temp++;
                }
                i++;
                i1--;
                j1--;
                }
                for(i=15*15-1; i>=0; i--)
                     printf("%5d",mas1[i]);
 
                printf("\n");               
  return 0;
}
1
kazak
3058 / 2379 / 255
Регистрация: 11.03.2009
Сообщений: 5,438
Завершенные тесты: 1
02.11.2009, 11:43 3
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
#include <iostream.h>
#include <iomanip.h>
 
int main(int argc, char* argv[])
{
   const int SIZE = 15;
   int arr[SIZE][SIZE] = {0};
   int iIndex, jIndex, n = 0, count = 1;
 
   iIndex = jIndex = SIZE / 2;
   while (n < SIZE)
   {
      for (int i = 0; i < n; i++)
      {
         arr[iIndex++][jIndex] = count++;
      }
      for (int i = 0; i < n; i++)
      {
         arr[iIndex][jIndex++] = count++;
      }
      n++;
      for (int i = 0; i < n; i++)
      {
         arr[iIndex--][jIndex] = count++;
      }
      for (int i = 0; i < n; i++)
      {
         arr[iIndex][jIndex--] = count++;
      }
      n++;
   }
   for (int i = 0; i < SIZE; i++)
   {
      for (int j = 0; j < SIZE; j++)
      {
         cout << setw(4) << arr[i][j];
      }
   cout << endl;
   }
   system("pause");
   return 0;
}
Программа заполняет массив по спирали числами в возрастающей последовательности, и выводит его на экран
2
odip
Эксперт С++
7162 / 3221 / 76
Регистрация: 17.06.2009
Сообщений: 14,161
02.11.2009, 21:17 4
Такое уже было в форуме.
0
AkA_ZadR
0 / 0 / 0
Регистрация: 07.09.2011
Сообщений: 8
22.09.2011, 19:15 5
а как сделать так
мы должны написать только 5 что значит размеры спирали (5*5)
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


5*5=25 25 в конце когда пишим 5 5 это a размеры a=a*a
0
22.09.2011, 19:15
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.09.2011, 19:15

Вывод матрицы по спирали
Массив по спирали я заполнил. Но нужно вывести его так, чтобы был видел...

Заполнение матрицы по спирали
Заполнить матрицу 10х10 числами от 1 до 100 по порядку, начиная с верхнего...

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


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru