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

Развернуть матрицу на 90o по часовой стрелке. - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.91
verona
0 / 0 / 0
Регистрация: 08.09.2010
Сообщений: 31
11.11.2010, 21:51     Развернуть матрицу на 90o по часовой стрелке. #1
Заполнить матрицу случайными числами. Развернуть матрицу на 90o по часовой стрелке.
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.11.2010, 21:51     Развернуть матрицу на 90o по часовой стрелке.
Посмотрите здесь:

C++ Развернуть матрицу на 90 градусов за часовой стрелкой.
C++ Заполнить матрицу случайными числами. Развернуть матрицу на 90(градусов) против часовой стрелки
Повернуть матрицу по часовой стрелке C++
повернуть квадратную матрицу на 90 градусов по часовой стрелке C++
C++ Матрицу повернуть на 90 градусов по часовой стрелке на C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
11.11.2010, 22:07     Развернуть матрицу на 90o по часовой стрелке. #2
verona, Транспонировать тащем-та?
verona
0 / 0 / 0
Регистрация: 08.09.2010
Сообщений: 31
11.11.2010, 22:14  [ТС]     Развернуть матрицу на 90o по часовой стрелке. #3
не важно как...лишь бы попроще
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
11.11.2010, 22:23     Развернуть матрицу на 90o по часовой стрелке. #4
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
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <iomanip>
 
int** trans(int** Arr, int n, int m)
{
    int** Obj;
    Obj=new int*[n];
    for(int i=0; i<n; ++i)
    {
        Obj[i]=new int[m];
    }
    for(int i=0; i<n; ++i)
    {
        for(int j=0; j<m; ++j)
        {
            Obj[i][j]=Arr[j][i];
        }
    }
    return Obj;
}
 
int main()
{
    srand(static_cast<unsigned>(time(0)));
    const int min=0;
    const int max=50;
    int** Arr;
    int n, m;
    std::cout<<"Enter n, m: ";
    std::cin>>n>>m;
    Arr=new int*[n];
    for(int i=0; i<n; ++i)
        Arr[i]=new int[m];
 
    for(int i=0; i<n; ++i)
    {
        for(int j=0; j<m; ++j)
        {
            Arr[i][j]=min+rand()%(max-min+1);
        }
    }
    std::cout<<"Matrix\n";
    for(int i=0; i<n; ++i)
    {
        for(int j=0; j<m; ++j)
        {
            std::cout<<std::setw(3)<<Arr[i][j]<<' ';
        }
        std::cout<<'\n';
    }
    try
    {
        if(n!=m)
        {
            throw ("Sizes are not equal for trans");
        }
    }
    catch(const char* s)
    {
        std::cerr<<s<<'\n';
        return 1;
    }
    Arr=trans(Arr, n, m);
    std::cout<<"Trans matrix\n";
    for(int i=0; i<n; ++i)
    {
        for(int j=0; j<m; ++j)
        {
            std::cout<<std::setw(3)<<Arr[i][j]<<' ';
        }
        std::cout<<'\n';
    }
    for(int i=0; i<n; ++i)
        delete[] Arr[i];
    delete[] Arr;
    return 0;
}
verona
0 / 0 / 0
Регистрация: 08.09.2010
Сообщений: 31
11.11.2010, 22:32  [ТС]     Развернуть матрицу на 90o по часовой стрелке. #5
так оно что-то не туда повернуло...и точнее не повернуло совсем...просто некоторые столбцы поменяло с рядками...но это не то((
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
11.11.2010, 22:36     Развернуть матрицу на 90o по часовой стрелке. #6
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Писал я когда-то давно это дело кому-то здесь, на форуме. Может не слишком "попроще", зато для любых матриц.

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
#include <iostream>
 
void rotateMatrix(double **matrix, int &rows, int &cols, int rotate_count)
{
    double temp;
    int min;
 
    for (int r = 0; r < rotate_count; r++)
    {
        if (rows == cols)
            min = rows;
        else
        {
            if (rows < cols)
            {
                min = rows;
 
                for (int j = 0; j < rows; j++)
                    matrix[cols - 1][j] = matrix[j][cols - 1];
            }
            else
            {
                if (rows > cols)
                {
                    min = cols;
 
                    for (int i = 0; i < cols; i++)
                        matrix[i][rows - 1] = matrix[rows - 1][i];
                }
            }
        }
 
 
        for (int i = 0; i < min; i++)
        {
            for (int j = i + 1; j < min; j++)
            {
                temp = matrix[i][j];
                matrix[i][j] = matrix[j][i];
                matrix[j][i] = temp;
            }
        }
 
        int tmp = rows;
        rows = cols;
        cols = tmp;
 
        for (int k = 0; k < rows; k++)
        {
            for (int i = 0, j = cols - 1; i <= j; i++, j--)
            {
                temp = matrix[k][i];
                matrix[k][i] = matrix[k][j];
                matrix[k][j] = temp;
            }
        }
    }
}
 
int main()
{
    int n, m;
    int max;
    int rot;
    double **matrix;
 
    std::cout << "Enter n: ";
    std::cin >> n;
    std::cout << "Enter m: ";
    std::cin >> m;
 
    max = (n > m) ? n : m;
 
    matrix = new double *[max];
 
    for (int i = 0; i < max; i++)
        matrix[i] = new double [max];
 
    std::cout << "Enter matrix:" << std::endl;
 
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            std::cout << "matrix[" << i << "][" << j << "] = ";
            std::cin >> matrix[i][j];
        }
    }
 
    std::cout << "Enter number of rotation: ";
    std::cin >> rot;
 
    rotateMatrix(matrix, n, m, rot);
 
    std::cout << "Output matrix" << std::endl;
 
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
            std::cout << matrix[i][j] << "   ";
 
        std::cout << std::endl;
    }
 
    for (int i = 0; i < max; i++)
        delete [] matrix[i];
 
    delete [] matrix;
 
    std::cin.get();
    return 0;
}
Добавлено через 38 секунд
И ещё сам задаёшь количество поворотов.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
11.11.2010, 22:40     Развернуть матрицу на 90o по часовой стрелке. #7
Тогда я просто не понял задание) Ссори)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.11.2010, 23:07     Развернуть матрицу на 90o по часовой стрелке.
Еще ссылки по теме:

Заполнить матрицу случайными числами. Вернуть матрицу на 90o по часовой стрелке C++
C++ Заполнить квадратную матрицу по спирали по часовой стрелке
Получить вторую матрицу путем поворота первой по часовой стрелке C++

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

Или воспользуйтесь поиском по форуму:
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
11.11.2010, 23:07     Развернуть матрицу на 90o по часовой стрелке. #8
ForEveR, вы были близки к истине. Чтобы повернуть матрицу по часовой стрелке, её надо транспонировать, а затем переставить местами 1 и k, 2 и k-1 и т.д. столбцы.
Yandex
Объявления
11.11.2010, 23:07     Развернуть матрицу на 90o по часовой стрелке.
Ответ Создать тему
Опции темы

Текущее время: 00:12. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru