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

Функция обходящая по спирали все элементы матрицы

25.05.2023, 01:54. Показов 664. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Проблема только в функции Z1
Задание такое: Дана квадратная матрица A размера m m , m – нечетное число. Начиная с центра,
обойти по спирали все элементы матрицы (распечатывая их в порядке обхода).
И чутка не допонимаю как это правильно сделать, и выдает ошибку на счет j, то что выражение должно иметь тип указателя на объект, но имеет тип int
Не могли бы помочь как правильно сделать функцию Z1

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
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
119
120
121
122
123
124
125
126
127
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <iomanip>
 
using namespace std;
 
void VVOD(int*, int, int);
void VIVOD(int*, int, int);
void RANDOM(int*, int, int);
void Z1(int*, int, int);
 
void VVOD(int* mas, int m, int n) 
{
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < n; j++) {
            printf("matr[%i][%i] = ", i, j);
            scanf_s("%i", &mas[i * n + j]);
        }
    }
}
 
void RANDOM(int* mas, int m, int n)
{
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < n; j++)
        {
            mas[i * n + j] = rand() % 100 - 50;
        }
    }
}
void VIVOD(int* mas, int m, int n) 
{
    
    printf("\n");
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < n; j++) {
            printf("%6i", mas[i * n + j]);
        }
        printf("\n");
    }
    printf("\n");
}
 
void Z1(int* mas, int m, int n)
{
    
    int i = m / 2, int j = n / 2;//устанавливаем итераторы на центральный элемент массива
    int z = 0;
 
        //цикл обхода по спирали по часовой стрелке  
        do {
            z++;//увеличиваем величину сдвига на 1
            for (int i = 0; i < m; i++)//выводим n элементов со сдвигом вверх
                cout << mas[i--][j] << ' ';
            //точка выхода из цикла
            if (z == m)//если сдвиг равен размерности массива
                break;//выход
            for (int j = 0; j < n; j++)//выводим n элементов со сдвигом вправо
                cout << mas[i][j++] << ' ';
            z++;//опять увеличиваем сдвиг
            for (int i = 0; i < m; i++)////выводим n элементов со сдвигом вниз
                cout << mas[i++][j] << ' ';
            for (int j = 0; j < n; j++)////выводим n элементов со сдвигом влево
                cout << mas[i][j--] << ' ';
 
        } while (z);
        return;
    
}
 
 
int main() 
{
    int m = 0, n = 0;
    setlocale(LC_ALL, "rus");
    int answer = 0;
    int a[15][15];
    do
    {
        printf("МЕНЮ\n");
        printf("1. Ввод матрицы\n");
        printf("2. Вывод матрицы\n");
        printf("3. Рандомное заполнение матрицы\n");
        printf("4. Преобразованная матрица:\n");
        printf("5.  Выход\n");
        printf("Введите номер пукта меню: ");
        scanf_s("%d", &answer);
        switch (answer) {
        case 1:
            printf("Введите размерность массива:");
            scanf_s("%i%i",&n,&m);
            if (n != 0)
                VVOD(&a[0][0], n, m);
            break;
        case 2:
            if (n > 0) {
                printf("Была введена матрица\n");
                VIVOD(&a[0][0], n, m);
            }
            else  printf("\nВведите массив\n\n");
            break;
        case 3:
            printf("Введите размерность массива:");
            scanf_s("%i%i", &n, &m);
            if (n != 0)
                RANDOM(&a[0][0], n, m);
            break;
        case 4:
            if (n > 0) {
                printf("Преобразованная матрица:");
                Z1(&a[0][0], n, m);
            }
            break;
        case 5:
            exit(0);
 
        default:
            printf("Выбран несуществующий пункт меню\n");
            break;
        }
    } while (1);
    //system("pause");
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.05.2023, 01:54
Ответы с готовыми решениями:

Из матрицы A сформировать матрицу B (по спирали), отсортировав по убыванию все элементы матрицы A
Я походу тупенький и уже овер дофига времени не могу сделать эту задачу: Из матрицы A сформировать матрицу B, отсортировав по убыванию...

Вывести все элементы матрицы по спирали
Дана квадратная матрица A порядка M (M — нечетное число). Начиная с первого элемента и перемещаясь против часовой стрелки, вывести все ее...

Вывести все элементы матрицы по спирали
Дана квадратная матрица A порядка M (M — нечетное число). Начиная с элемента A0,0 и перемещаясь против часовой стрелки, вывести все ее...

4
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12938 / 6805 / 1821
Регистрация: 18.10.2014
Сообщений: 17,224
25.05.2023, 02:22
Цитата Сообщение от aslan2005 Посмотреть сообщение
cout << mas[i--][j] << ' ';
Так а что это такое? Откуда взялись двойные [][]? Вы же сами в функциях выше работаете с вашим массивом совсем по-другому. Никаких [][] там нет. Почему в этой функции внезапно возникли затруднения?

Цитата Сообщение от aslan2005 Посмотреть сообщение
int a[15][15];
Нет, так нельзя. Ваши функции предназначены для эмуляции двумерного массива через одномерный массив. То есть везде у вас в программе будут использоваться только одномерные массивы.
0
0 / 0 / 0
Регистрация: 20.12.2022
Сообщений: 35
25.05.2023, 18:10  [ТС]
ТАк, и что нужно все-таки сделать?
Я не понимаю
0
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12938 / 6805 / 1821
Регистрация: 18.10.2014
Сообщений: 17,224
25.05.2023, 19:45
Цитата Сообщение от aslan2005 Посмотреть сообщение
ТАк, и что нужно все-таки сделать?
Я не понимаю
В смысле? У вас же в остальных функциях все сделано правильно. Как так получилось, что в остальных "понимаю", а в этой - "не понимаю"?
0
0 / 0 / 0
Регистрация: 20.12.2022
Сообщений: 35
25.05.2023, 20:18  [ТС]
Потому что я не знаю, как сделать эту задачу, и нашел похожее решение в интернете
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.05.2023, 20:18
Помогаю со студенческими работами здесь

Вывести все элементы матрицы по спирали
Pomogite pozhaluista!!!!!Дана квадратная матрица A порядка M (M — нечетное число). Начиная с элемента A1,1 и перемещаясь против часовой...

Обойти по спирали все элементы матрицы 6x6
C++ Начиная с центра, обойти по спирали все элементы матрицы 6x6, распечатывая их в порядке обхода.

Начиная с центра обойти по спирали все элементы матрицы
начиная с центра обойти по спирали все элементы матрицы размером 9х9

Начиная с центра, обойти по спирали все элементы квадратной матрицы
В целочисленной квадратной матрице nxn (3&lt;=n&lt;=101, n - нечетное) - найти номер первого из столбцов, не содержащих положительных...

Начиная с центра, обойти по спирали все элементы квадратной матрицы
Добрый день, ребята!!! не подскажите в написании программки??? Начиная с центра, обойти по спирали все элементы квадратной матрицы размером...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь 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. На борту пять. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru