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

Заполнить квадратную матрицу змейкой

14.10.2014, 21:53. Показов 3384. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
заполнить квадратную матрицу NxN змейкой С++
вот так:
25 24 23 22 21
16 17 18 19 20
15 14 13 12 11
6 7 8 9 10
5 4 3 2 1
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.10.2014, 21:53
Ответы с готовыми решениями:

Заполнить квадратную матрицу змейкой
Задано число N. Заполните квадратную матрицу NxN числами от 1 до N^2 “змейкой”, как показано в примере. 4 1 8 9 16 2 7 10 15...

Заполнить квадратную матрицу 10 на 10 змейкой
заполнить квадратную матрицу 10 на 10 змейкой С++ вот так: 91 92 93 94...98 99 100 90 89 88 87...83 82 81 . . . 11 12 13...

Двухмерный массив (заполнить змейкой квадратную матрицу)
Требуется заполнить змейкой квадратную матрицу так, как показано на рисунке справа: заполнение происходит с единицы из левого верхнего угла...

4
5 / 5 / 4
Регистрация: 13.05.2014
Сообщений: 130
14.10.2014, 22:13
Лучший ответ Сообщение было отмечено mik-a-el как решение

Решение

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
#include <iostream>
 
 
const int MATRIX_SIZE = 5;
 
void fill_matrix_snake(int ** matrix);
void show_matrix(int ** matrix);
 
int main()
{
    int ** matrix = new int * [MATRIX_SIZE];   
    for (int i=0; i<MATRIX_SIZE; ++i)         
        matrix[i] = new int[MATRIX_SIZE];     
 
    fill_matrix_snake(matrix);
    show_matrix(matrix);
 
    for (int i = 0; i<MATRIX_SIZE; ++i)   
        delete [] matrix[i];
    delete [] matrix;
 
    return 0;
}
int first, last, add;
 
 
 
void fill_matrix_snake(int ** matrix)
{
    int counter = 25;
    int first, last, add;
    for (int i=0; i<MATRIX_SIZE; ++i)
    {
        if (i&1)
        {
            first = 0;
            last = MATRIX_SIZE;
            add = 1;
        }
 
        else
        {
            first = MATRIX_SIZE - 1;
            last = -1;
            add = -1;
        }
 
        for (int j=first; j!=last; j+=add)
            matrix[i][j] = counter--;
    }
}
 
void show_matrix(int ** matrix)
{
    for (int i=0; i<MATRIX_SIZE; ++i)
    {
        for (int j=0; j<MATRIX_SIZE; ++j)
            std::cout << matrix[i][j] << "\t";
        std::cout << std::endl;
    }
}
Добавлено через 1 минуту
Это так как тебе надо

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
#include <iostream>
 
 
const int MATRIX_SIZE = 5;
 
void fill_matrix_snake(int ** matrix);
void show_matrix(int ** matrix);
 
int main()
{
    int ** matrix = new int * [MATRIX_SIZE];   
    for (int i=0; i<MATRIX_SIZE; ++i)         
        matrix[i] = new int[MATRIX_SIZE];     
 
    fill_matrix_snake(matrix);
    show_matrix(matrix);
 
    for (int i = 0; i<MATRIX_SIZE; ++i)   
        delete [] matrix[i];
    delete [] matrix;
 
    return 0;
}
int first, last, add;
 
 
 
void fill_matrix_snake(int ** matrix)
{
    int counter = 25;
    int first, last, add;
    for (int i=0; i<MATRIX_SIZE; ++i)
    {
        if (i&1)
        {
            first = MATRIX_SIZE - 1;
            last = -1;
            add = -1;
        }
 
        else
        {
            first = 0;
            last = MATRIX_SIZE;
            add = 1;
        }
 
        for (int j=first; j!=last; j+=add)
            matrix[i][j] = counter--;
    }
}
 
void show_matrix(int ** matrix)
{
    for (int i=0; i<MATRIX_SIZE; ++i)
    {
        for (int j=0; j<MATRIX_SIZE; ++j)
            std::cout << matrix[i][j] << "\t";
        std::cout << std::endl;
    }
}
0
365 / 321 / 219
Регистрация: 21.02.2013
Сообщений: 756
14.10.2014, 22:28
Лучший ответ Сообщение было отмечено alewka как решение

Решение

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
#include <iostream>
using namespace std;
 
int main()
{
    int arr[5][5];
    int counter = 25;
    for(int i = 0; i != 5; i++)
    {
        if(i%2 == 0)
        for(int j = 0; j != 5; j++)
        {
            arr[i][j] = counter--;
 
        }
        else
        for(int j = 4; j >=0; j--)
        {
            arr[i][j] = counter--;
 
        }
 
    }
    for(int i = 0; i != 5; i++)
    {
        for(int j = 0; j != 5; j++)
        {
            cout << arr[i][j] <<" ";
        }
        cout << endl;
    }
    return 0;
}
1
0 / 0 / 0
Регистрация: 14.10.2014
Сообщений: 36
15.10.2014, 04:33  [ТС]
спасибо большое, а можно переделать эту программу вот ...
21 22 23 24 25
20 19 18 17 16
11 12 13 14 15
10 9 8 7 6
1 2 3 4 5
0
Модератор
Эксперт CЭксперт С++
 Аватар для sourcerer
5288 / 2376 / 342
Регистрация: 20.02.2013
Сообщений: 5,773
Записей в блоге: 20
15.10.2014, 07:41
alewka, Вы бы уже разобрались, что происходит в коде и переделали бы сами. Задачка-то элементарная. Если ничего не понятно, то книжку почитайте. Любую нормальную книжку по C++.
Или в сети посмотрите - сайтов полно (например, учебные материалы с нуля: раз, два; справочные материалы: раз, два).

Конкретно под Вашу задачу почитайте про двумерные массивы (матрицы), динамическое выделение памяти, цикл for, оператор if else.
Час чтения, час практики, итого - два часа потраченного времени. Зато сразу +10 к самоуважению и +10 к новым знаниям.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.10.2014, 07:41
Помогаю со студенческими работами здесь

Требуется заполнить змейкой квадратную матрицу так, как показано на рисунке
Требуется заполнить змейкой квадратную матрицу так, как показано на рисунке справа: заполнение происходит с единицы из левого верхнего угла...

Заполнить квадратную матрицу змейкой по диагонали, начиная с элемента matrix[size-1][size-1]
Требуется написать программу, которая заполняет массив размерности n*n по заданному правилу: 25 23 22 16 15 24 ...

Заполнить матрицу змейкой
Напишите программу, заполняющую матрицу nxn (значение значение n вводить с клавиатуры) по правилу, которое представлено на примере...

Заполнить матрицу змейкой
1 8 9 16 2 7 10 16 3 6 11 14 4 5 12 13

Заполнить матрицу змейкой
Нужно заполнить квадратный двухмерный масив змейкой и вывести. 1 2 3 6 5 4 7 8 9


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru