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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.91
verona
0 / 0 / 0
Регистрация: 08.09.2010
Сообщений: 31
#1

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

11.11.2010, 21:51. Просмотров 1599. Ответов 7
Метки нет (Все метки)

Заполнить матрицу случайными числами. Развернуть матрицу на 90o по часовой стрелке.
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.11.2010, 21:51
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Развернуть матрицу на 90o по часовой стрелке. (C++):

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

Повернуть матрицу по часовой стрелке - C++
Что нужно сделать, чтобы повернуть матрицу по часовой стрелке?? если меняешь i и j местами, но она повернется против часовой на 90...

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

Матрицу повернуть на 90 градусов по часовой стрелке на C++ - C++
Содержимое квадратной матрицы A(n,n) повернуть на 90 градусов по часовой стрелке, считая центром поворота центр симметрии матрицы.

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

Повернуть квадратную матрицу на 90 градусов по часовой стрелке - C++
повернуть квадратную матрицу на 90 градусов по часовой стрелке

7
ForEveR
В астрале
Эксперт С++
7979 / 4738 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
11.11.2010, 22:07 #2
verona, Транспонировать тащем-та?
0
verona
0 / 0 / 0
Регистрация: 08.09.2010
Сообщений: 31
11.11.2010, 22:14  [ТС] #3
не важно как...лишь бы попроще
0
ForEveR
В астрале
Эксперт С++
7979 / 4738 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
11.11.2010, 22:23 #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;
}
1
verona
0 / 0 / 0
Регистрация: 08.09.2010
Сообщений: 31
11.11.2010, 22:32  [ТС] #5
так оно что-то не туда повернуло...и точнее не повернуло совсем...просто некоторые столбцы поменяло с рядками...но это не то((
0
silent_1991
Эксперт С++
4985 / 3042 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
11.11.2010, 22:36 #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 секунд
И ещё сам задаёшь количество поворотов.
3
ForEveR
В астрале
Эксперт С++
7979 / 4738 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
11.11.2010, 22:40 #7
Тогда я просто не понял задание) Ссори)
1
silent_1991
Эксперт С++
4985 / 3042 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
11.11.2010, 23:07 #8
ForEveR, вы были близки к истине. Чтобы повернуть матрицу по часовой стрелке, её надо транспонировать, а затем переставить местами 1 и k, 2 и k-1 и т.д. столбцы.
2
11.11.2010, 23:07
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.11.2010, 23:07
Привет! Вот еще темы с ответами:

Переписать данные из массива в матрицу ползунком, и спиралью по часовой стрелке - C++
Здравствуйте, у меня задание есть, не как не могу придумать решение проблемы, вот у меня есть программа #include &quot;stdafx.h&quot; #include...

Получить вторую матрицу путем поворота первой по часовой стрелке - C++
Дана двумерная матрица действительных чисел А. Необходимо получить двумерный масив В путем поворота первого по часовой стрелке. Вводить...

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

Повернуть массив на 90° по часовой стрелке - C++
С помощью генератора случайных чисел заполните двумерный массив NxN числами в интервале 10-99, и выведете его на экран. Поверните массив на...


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

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

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