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

Заполнение матрицы змейкой - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Получить все числа, входящие в последовательность только один раз http://www.cyberforum.ru/cpp-beginners/thread907864.html
Даны массив целых чисел. Получить все числа, входящие в последовательность только один раз.
C++ Вычислить y Параметр цикла с индексной переменной: Обозначение индекса - k Номер индекса - 1 1.3 2 -1.6 3 -2.3 1 4.51 2 -4.16 3 2.61 4 7.28 http://www.cyberforum.ru/cpp-beginners/thread907858.html
C++ пользовательская функция для массивов
Вот собственно код, почему же он не выводит мне массив через функцию?? Где у меня ошибка? помогите пжл) ifstream in_stream; ofstream out_stream; in_stream.open("d:/N1.txt"); cout <<...
C++ Сформировать из матрицы вектор по правилу
Дано матрицу размером MxN. Сформировать из этой матрицы вектор по правилу: первые N элементов вектора - это элементы матрицы первой строки, вторая N элементов - элементы второй строки и т.д. (М = 4,...
C++ Цикл (C++) http://www.cyberforum.ru/cpp-beginners/thread907852.html
Помогите решить, пожалуйста
C++ Составить программу, которая определяет, существует ли треугольник Составить программу, которая определяет, существует ли треугольник, используя функцию: bool treugolnik(float a, float b, float c) {bool flag=false; if (a<b+с && b<a+с && c<a+b) flag=true; return... подробнее

Показать сообщение отдельно
LifeWind
4 / 4 / 1
Регистрация: 13.09.2012
Сообщений: 36
20.06.2013, 21:19  [ТС]
Вот, нашел такую змейку, только не знаю, что там изменить, чтобы заполняла по моему рисунку. Изменял координаты Х, но не вышло.
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
#include <iostream>
#include <iomanip>
using namespace std;
void func(int **array, int n)
{
      int x, y,  // Координаты текущего элемента массива
        value = 1; // значение, которым заполняется массив
 int diag1=n-1;
    // зполнение первой половины массива по диагонали, зигзагом, начиная
    // слева и сверху, заканчивая  побочной диагональю
    for (int diag = 0; diag < n; diag++) // выполняем проход по диагоналям
    {
        if (diag % 2 == 0) // по четным диагоналям
        {
            x = n-1; // х-координата первого лемента массива на диагонали - diag
            y = diag; // у-координата элемента массива на диагонали - diag
 
            while (y >= 0) // пока y-координата находится в верхней части диагонали
            {
                array[x][y] = value; // записать значение в массив
                value++;
                x--;     // по горизонтали, смещаемся влево
                y--;    // по вертикали, смещаемся вниз
            }
        }
        else // по нечетным диагоналям
        {
            x = diag1; // х-координата элемента массива на диагонали - diag
            y = 0; // у-координата первого элемента массива на диагонали - diag
 
            while (x >= n-1) // пока x-координата находится в левой части диагонали
            {
                array[x][y] = value; // записать значение в массив
                value++;
                x ++;  // по горизонтали, смещаемся вправо
                y ++; // по вертикали, смещаемся вверх
            }
        }
        diag1--;
    } // конец for
 diag1=n-2;
    // заполнение второй половины массива по диагонали, зигзагом, начиная
    // слева и сверху, заканчивая  последним элементом массива
    for (int diag = 1; diag < n; diag++)
    {
        if (diag % 2 == 0) // по четным диагоналям
        {
            x = 0; // х-координата первого элемента массива на диагонали - diag
            y = diag;  // у-координата элемента массива на диагонали - diag
 
            while (y <= n - 1) // Пока не кончилась диагональ
            {
                array[x][y] = value;
                value++;
                x++; // по горизонтали, смещаемся влево
                y++; // по вертикали, смещаемся вниз
            }
        }
        else // по не четным диагоналям
        {
            x = diag1; // х-координата первого элемента к-ой диагонали
            y = n - 1;  // у-координата первого элемента к-ой диагонали
 
            while (x >= 0) // Пока не кончилась диагональ
            {
                array[x][y] = value;
                value++;
                x--; // по горизонтали, смещаемся вправо
                y--; // по вертикали, смещаемся вверх
            }
        } // конец if-else
    } // конец цикла for (заполнение второй половины массива)   
 
    return;
}
 
void printmatrix(int **array, int n)
{
    // вывод масиива на экран
    for (int ix = 0; ix < n; ix++)
    {
        for (int jx = 0; jx < n; jx++)
            cout << setw(4) << array[ix][jx] << " ";
        cout << endl;
    }
    return;
}
void main()
{
    setlocale(LC_ALL, "Russian" ); 
 
    int n; // количество столбцов массива
    cout << "Введите размерность матрицы: "<<endl;
    cin >> n;
    int **array;
    array=new int *[n];
    for(int i=0; i<n; i++)
        array[i]= new int[n];
    func(array,n);
    printmatrix(array,n);
    return;
}
0
Изображения
 
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru