Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 1
Регистрация: 12.12.2012
Сообщений: 76

Заполнение матрицы по спирали с использованием case - break

27.01.2013, 14:08. Показов 1065. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно заполнить матрицу по спирали при помощи case - break. Вот код :
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
#include<iostream>
#include<Windows.h>
#include "stdlib.h"
using namespace std;
 
void main()
{
    SetConsoleOutputCP(1251);
    const int N=5, M=5;
    int A[N][M];
    int i, j, k, l, r, t, b, dir=0;
    //заполние матрицы
    k=1;
    t=0;    l=0;    r=N-1;  b=M-1;
    while(l<=r && t>=b)
        {
         switch(dir)
                {
                    case 0://l..r заполнение справа налево
                            for (i=l; i<=r; i++, k++)
                                    A[t][i]=k;
                                    t++;
                        break;
                    case 1://t..b заполнение сверху вниз
                            for (i=t; i<=b; i++, k++)
                                A[r][i]=k;
                                r--;
                        break;
                    case 2://r..l заполнение слева направо
                            for (i=r; i<=l; i--, k++)
                                A[b][i]=k;
                                b--;
                        break;
                    case 3://b..t заполнение снизу вверх
                            for (i=b; i<=t; i--, k++)
                                A[l][i]=k;
                                l++;
                        break;
                }
            dir=(dir+1)%4; //счетчик направления
        }
        //вывод полученной матрицы    
    system("cls");
        for (i=0; i<N; i++)
            {
                for (j=0; j<M; j++)
                    {
                        cout<<A[i][j]<<" ";
                        Sleep(500);
                    }
            cout<<"\n";
        }
            
}
,

но на выходе получается
Миниатюры
Заполнение матрицы по спирали с использованием case - break  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.01.2013, 14:08
Ответы с готовыми решениями:

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

Заполнение матрицы по спирали
Всем привет! Интересную задачу решаю) Задача Для матрицы задается любое число , скажем 9 и на консоль должно выходить вот...

Заполнение матрицы по спирали
При заполнении матрицы 10 на 8 выдаёт ошибку, помогите исправить int n = Convert.ToInt32(Console.ReadLine()); ...

6
ComfyMobile
 Аватар для Nixy
401 / 282 / 34
Регистрация: 24.07.2012
Сообщений: 916
27.01.2013, 14:14
что такое t? правильно ил вы его инициализировали? вот это условие не срабатывает
C++
1
while(l<=r && t>=b)
0
0 / 0 / 1
Регистрация: 12.12.2012
Сообщений: 76
27.01.2013, 14:27  [ТС]
t - это верхняя граница матрицы,
l - левая граница матрицы,
r - правая граница матрицы
b - нижняя граница матрицы
0
ComfyMobile
 Аватар для Nixy
401 / 282 / 34
Регистрация: 24.07.2012
Сообщений: 916
27.01.2013, 14:42
да я уже разобрался, у вас логика нарушена, я почти закончил исправление, мне осталось только понять как последний элемент сделать

Добавлено через 5 минут
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
#include<iostream>
#include<Windows.h>
#include "stdlib.h"
using namespace std;
 
int main()//вы програмируте на С++ а значит по стандарту возврашать обязаны int
{
    SetConsoleOutputCP(1251);
    const int N=6, M=6;
    int A[N][M];
    int i, j, k, l, r, t, b, dir=0;
    //заполние матрицы
    k=1;
    t=0;    l=0;    r=N-1;  b=M-1;
    while(l < r | t < b | k < N*M+1) // меняем на логическое ИЛИ  и добовляем проверку счетчика для последнего элемента
        {
         switch(dir)
                {                         //во первых тут слева направо
                    case 0://l..r заполнение cлева направо
                            for (i=l; i<=r; i++, k++)
                                    A[t][i] = k;
                                    t++;
 
                        break;          // если движемся по строке то и индекс в строке
                    case 1://t..b заполнение сверху вниз
                            for (i=t; i<=b; i++, k++)
                                A[i][r] = k;
                                r--;
 
                        break;
                    case 2://r..l заполнение справо на лево
                            for (i=r; i >= l; i--, k++)
                                A[b][i] = k;
                                b--;
                        break;                 // тут тоже индекс в строке должен быть
                    case 3://b..t заполнение снизу вверх
                            for (i=b; i >= t; i--, k++)
                                A[i][l] = k;
                                l++;
                        break;
                }
            dir=(dir+1)%4; //счетчик направления
        }
        //вывод полученной матрицы
    system("cls");
        for (i=0; i < N; i++)
            {
                for (j=0; j < M; j++)
                    {
                        cout<<A[i][j]<<" ";
                        Sleep(500);
                    }
            cout<<"\n";
        }
        system ("pause");
      //причем явно возврашать 0 необязательно  return 0;
}
0
0 / 0 / 1
Регистрация: 12.12.2012
Сообщений: 76
27.01.2013, 15:44  [ТС]
Все равно результат тот же что и был
0
Модератор
Эксперт по электронике
8978 / 6744 / 921
Регистрация: 14.02.2011
Сообщений: 23,852
27.01.2013, 15:49
По спирали это как?
от центра к краям?
7 8 9
6 1 2
5 4 3
или от края к центру?
1 2 3
8 9 4
7 6 5
0
ComfyMobile
 Аватар для Nixy
401 / 282 / 34
Регистрация: 24.07.2012
Сообщений: 916
27.01.2013, 15:57
Цитата Сообщение от morfei74 Посмотреть сообщение
Все равно результат тот же что и был
не может быть такого,
Миниатюры
Заполнение матрицы по спирали с использованием case - break   Заполнение матрицы по спирали с использованием case - break  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.01.2013, 15:57
Помогаю со студенческими работами здесь

Заполнение матрицы по спирали
#include &lt;iostream&gt; #include &lt;iomanip&gt; using namespace std; int main() { setlocale(LC_ALL, &quot;Russian&quot;); int N, M; cout &lt;&lt;...

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

Заполнение матрицы по спирали
Вывести на языке СИ такую матрицу (5 на 5, размерность можно изменять) 1 2 3 4 5 16 17 18 19 6 15 24 25 ...

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

Заполнение матрицы по спирали
Всем привет! Думал вроде легкая задача, но зашел в тупик. Помогите пожалуйста. На форуме искал, но такого заполнения не нашел. ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru