Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 50, средняя оценка - 4.98
Attractive_girl
0 / 0 / 0
Регистрация: 01.11.2009
Сообщений: 3
#1

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

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

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

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

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

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

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

Заполнение матрицы по спирали - C++
Напишите программу, которая заполняет матрицу из N строк и M столбцов заполненную заданным способом: входные данные: 4 5 выходные...

Заполнение матрицы по спирали - C++
Здравствуйте! Помогите, пожалуйста, с задачей: Заполнить квадратную матрицу nxn последовательными целыми числами от 1 до n^2,...

4
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 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
3035 / 2356 / 155
Регистрация: 11.03.2009
Сообщений: 5,402
Завершенные тесты: 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
Эксперт С++
7157 / 3219 / 59
Регистрация: 17.06.2009
Сообщений: 14,164
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
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.09.2011, 19:15
Привет! Вот еще темы с ответами:

Заполнение матрицы по спирали - C++
Заполнить матрицу 10х10 числами от 1 до 100 по порядку, начиная с верхнего левого угла. #include&lt;conio.h&gt; #include&lt;stdio.h&gt; ...

Заполнение матрицы по спирали - C++
Дано натуральное N (1&lt;=N&lt;=10). Заполнить матрицу порядка N*N целыми числами 0, 1, 2, 3, …, N^2–1 по спирали(по часовой стрелке). Важное...

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

Заполнение матрицы по спирали - C++
Привет всем, можете помочь пожалуйста: надо придумать алгоритм, написать код на С++ заполнения матрицы по контуру по часовой стрелке (т.е....


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

Или воспользуйтесь поиском по форуму:
5
Yandex
Объявления
22.09.2011, 19:15
Ответ Создать тему
Опции темы

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