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

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

Войти
Регистрация
Восстановить пароль
 
Sanya1
0 / 0 / 0
Регистрация: 05.07.2015
Сообщений: 43
#1

Заполнить квадратную матрицу натуральными числами по спирали - C++

05.07.2015, 17:28. Просмотров 1108. Ответов 2
Метки нет (Все метки)

Составить программу, которая заполняет квадратную матрицу порядка n натуральными числами 1, 2, 3, …, n2, записывая их в нее «по спирали» против часовой стрелки.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.07.2015, 17:28
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Заполнить квадратную матрицу натуральными числами по спирали (C++):

Улитка.Матрицу M (m,n) заполнить натуральными числами от 1 до m*n по спирали, начинающей в левом верх - C++
Помогите пожалуйста решить задачу по BORLAND С++ Улитка.Матрицу M (m,n) заполнить натуральными числами от 1 до m*n по спирали, начинающей...

Заполнить квадратную матрицу числами по спирали - C++
Задача B. Спираль В этой задаче вам необходимо вывести квадрат, состоящий из NxN клеток, заполненных числами от 1 до N2 по спирали...

Заполнить заданную квадратную матрицу по спирали числами 0 и 1 - C++
Всем привет! Поставили передо мной следующую задачу: Написать программу, которая заполняет матрицу NxN (1 <= N <= 50) числами 1 и 0 по...

Заполните матрицу натуральными числами по спирали и змейкой - C++
Заполните матрицу, содержащую N строк и M столбцов, натуральными числами по спирали и змейкой, то есть типо этого: 1 2 3 4 5 6...

Заполнить квадратную матрицу по спирали - C++
Одномерный: В заданном целочисленном массиве R(9) определить индекс наибольшего из нечетных по значению положительных элементов. ...

Заполнить квадратную матрицу размером N x N по спирали - C++
Заполнить квадратную матрицу размером N x N по спирали (N – нечётное число). Число 1 ставится в центр матрицы, а затем массив...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
zss
Модератор
Эксперт С++
6382 / 5947 / 1927
Регистрация: 18.12.2011
Сообщений: 15,264
Завершенные тесты: 1
05.07.2015, 18:05 #2
Заполнить квадратную матрицу размером N x N по спирали
0
camelx
0 / 0 / 0
Регистрация: 06.07.2015
Сообщений: 2
06.07.2015, 16:07 #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
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
#include <stdio.h>
#include <cstdlib>
#include <iostream>
 
using namespace std;
int main(){
    setlocale(LC_ALL, "RUSSIAN");
    //Ввод параметров матрицы
    cout << "Введите ширину матрицы:  ";
    int nX;
    cin >> nX;
    cout << "Введите длину матрицы:   ";
    int nY;
    cin >> nY;
    //Создание динамического массива
    int **massiv = new int*[nX];
    for (int tmp = 0; tmp < nX; tmp++)  massiv[tmp] = new int[nY];
    
    int i = 0, j = 0, c = 0, d = 1;
    int a = nX;
    int b = nY;
    int nLastNumber = 1; //Счетчик ячеек матрицы
    int maxNumber = nY*nX; //Максивальное число матрицы
    
    while (true){ //Крутим цыкл пока не заполним все ячейки - 
        a--;
        b--;
        
        while (j < b){
            massiv[i][j] = nLastNumber;
            nLastNumber++;
            j++;
        }
        if (nLastNumber == maxNumber) break;
 
        while (i < a){
            massiv[i][j] = nLastNumber;
            nLastNumber++;
            i++;
        }
        if (nLastNumber == maxNumber) break;
 
        j = b;
        i = a;
                
        while (j > c){
            massiv[i][j] = nLastNumber;
            nLastNumber++;
            j--;
        }
        if (nLastNumber == maxNumber) break;
        
        while (i > d){
 
            massiv[i][j] = nLastNumber;
            nLastNumber++;
            i--;
        }
        if (nLastNumber == maxNumber)  break;
 
        j = c;
        i = d;
        c++;
        d++;
 
 
    }
    massiv[i][j] = maxNumber; 
    //Вывод матрицы
    for (j = 0; j < nY; j++){
        cout << "\n";
        for (i = 0; i < nX; i++){
            cout << massiv[i][j] << "\t";
        }
    }
    //Удаление динамического массива
    for (i = 0; i < nX; i++) delete[] massiv[i];
    delete[] massiv;
    cout << "\n";
    system("pause");
    return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.07.2015, 16:07
Привет! Вот еще темы с ответами:

Заполнить целочисленную квадратную матрицу по спирали - C++
Получить целочисленную квадратную матрицу порядка 2n+1, элементами которой являются числа 1, 2, 3, ... , (2*n + 1), расположенные в...

Заполнить матрицу последовательными натуральными числами - C++
1.Сформировать матрицу по следующему правилу 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 ...

Заполнить квадратную матрицу по спирали по часовой стрелке - C++
Нужно составить программу, которая заполняет квадратную матрицу порядка n натуральными числами 1, 2, 3, ... n, записывая их в нее &quot;по...

Заполнить квадратную матрицу от левого верхнего угла по спирали - C++
Заполнить матрицу А(9,9), от левого верхнего угла по спирали: вправо - вниз - влево - вверх.


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

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

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