Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/13: Рейтинг темы: голосов - 13, средняя оценка - 4.62
1 / 1 / 0
Регистрация: 04.11.2013
Сообщений: 47

Осуществить циклический сдвиг элементов квадратной

17.01.2014, 22:40. Показов 2768. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Осуществить циклический сдвиг элементов квадратной матрицы на n элементов вправо или вниз (в зависимости от введенного режима), n может быть больше количества элементов в стро-ке или столбце.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.01.2014, 22:40
Ответы с готовыми решениями:

Осуществить циклический сдвиг элементов квадратной матрицы
(Console Application) Осуществить циклический сдвиг элементов квадратной матрицы размером М х N вправо на k элементов таким образом:...

Осуществить циклический сдвиг элементов квадратной матрицы
Помогите решить эту задачу: Осуществить циклический сдвиг элементов квадратной матрицы размерности М х N вправо на К элементов следующим...

Как осуществить циклический сдвиг элементов квадратной матрицы
Помогите осуществить циклический сдвиг элементов квадратной матрицы размерности MXN вправо на k элементов таким образом: элементы 1-й...

10
176 / 144 / 70
Регистрация: 01.05.2012
Сообщений: 414
18.01.2014, 03:40
решение с использованием STL)
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>
#include <vector>
#include <algorithm>
using namespace std;
 
int main()
{
    int N,M;
    cin>> N >>M;
    vector <vector <int> > A (N,vector<int> (M));
    for (int i=0; i<N; i++)
        for (int j=0; j<M; j++)
            cin >> A[i][j];
 
    int a;
    cout << "Куда сдвиать? 1-вправо, 2-вниз";
    cin >> a;
    cout <<"На сколько сдвигать? ";
 
    int n;
    cin>>n;
    if (a==1)
    {
        n=n%N;
        n=N-n;
        if (n)
        {
            reverse(A.begin(),A.begin()+n);
            reverse(A.begin()+n,A.end());
            reverse(A.begin(),A.end());
        }
    }
    else
    if (a==2)
        {
            n=n%M;
            n=M-n;
            if (n)
            for (int i=0; i<N; i++)
            {
                reverse(A[i].begin(),A[i].begin()+n);
                reverse(A[i].begin()+n,A[i].end());
                reverse(A[i].begin(),A[i].end());
            }
        }
    else
    {
        cout <<"Не верный выбор!";
        return 0;
    }
 
    for (int i=0; i<N; i++)
    {
        for (int j=0; j<M; j++)
        {
            cout << A[i][j]<<" ";
        }
        cout << endl;
    }
    return 0;
}
алгоритм сдвига влево такой:
1) переворачиваем первые n элементов
2) переворачиваем вторую часть элементов
3) переворачиваем весь массив

если нам надо вправо на n, то можно сдвинуть влево на N-n. Это одно и тоже.
1
1 / 1 / 0
Регистрация: 04.11.2013
Сообщений: 47
18.01.2014, 03:51  [ТС]
Цитата Сообщение от _script_ Посмотреть сообщение
решение с использованием STL)
при запуске программы висит пустое окно ( vs 2010)
0
176 / 144 / 70
Регистрация: 01.05.2012
Сообщений: 414
18.01.2014, 03:53
Вот еще решение без использования STL
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
#include <iostream>
 
using namespace std;
 
template <class T>
void Revers(T *A,int a, int b) //Функция переворота массива
{
    for (int i=a, j=b-1; i<j; i++, j--)
    {
        swap(A[i],A[j]);
    }
}
 
int main()
{
    int N,M;
    cin>> N >>M;
    int **A=new int*[N];
    for (int i=0; i<N; i++)
        A[i]=new int[M];
 
    for (int i=0; i<N; i++)
        for (int j=0; j<M; j++)
            cin >> A[i][j];
 
    int a;
    cout << "Куда сдвиать? 1-вправо, 2-вниз";
    cin >> a;
    cout <<"На сколько сдвигать? ";
 
    int n;
    cin>>n;
    if (a==1)
    {
        n=n%N;
        n=N-n;
        if (n)
        {
            Revers(A,0,n);
            Revers(A,n,N);
            Revers(A,0,N);
        }
    }
    else
    if (a==2)
        {
            n=n%M;
            n=M-n;
            if (n)
            for (int i=0; i<N; i++)
            {
                 Revers(A[i],0,n);
                 Revers(A[i],n,M);
                 Revers(A[i],0,M);
            }
        }
    else
    {
        cout <<"Не верный выбор!";
        return 0;
    }
 
    for (int i=0; i<N; i++)
    {
        for (int j=0; j<M; j++)
        {
            cout << A[i][j]<<" ";
        }
        cout << endl;
    }
    return 0;
}
Добавлено через 1 минуту
Цитата Сообщение от Bob_Sagen Посмотреть сообщение
при запуске программы висит пустое окно ( vs 2010)
Можете добавить перед cin>> N >>M;
cout << "введите N и М:";
а после
cin>> N >>M;
cout << "введите матрицу:";
2
 Аватар для cooller
571 / 539 / 280
Регистрация: 25.12.2013
Сообщений: 1,456
18.01.2014, 03:55
Цитата Сообщение от Bob_Sagen Посмотреть сообщение
при запуске программы висит пустое окно ( vs 2010)
В это пустое окно нужно начинать вводить данные
1
1 / 1 / 0
Регистрация: 04.11.2013
Сообщений: 47
18.01.2014, 04:02  [ТС]
Цитата Сообщение от cooller_94 Посмотреть сообщение
В это пустое окно нужно начинать вводить данные
после ввода n ,m и матрицы , дальше что не вводи бесполезно, ничего не происходит
0
176 / 144 / 70
Регистрация: 01.05.2012
Сообщений: 414
18.01.2014, 04:08
Цитата Сообщение от Bob_Sagen Посмотреть сообщение
после ввода n ,m и матрицы , дальше что не вводи бесполезно, ничего не происходит
M и N это размерность матрицы.
вы ввели размер 10 на 15 и вы должны ввести матрицу размером 10 на 15
соответственно должно быть введено 150 чисел)

введите матрицу по меньше, 3 на 3, например.
2
 Аватар для cooller
571 / 539 / 280
Регистрация: 25.12.2013
Сообщений: 1,456
18.01.2014, 04:08
Bob_Sagen, Картинка маленькая, ничего не видно
Цитата Сообщение от Bob_Sagen Посмотреть сообщение
после ввода n ,m и матрицы , дальше всё в пустую идёт
Все работает, я проверил.
Вы вводите сначала размерности матрицы, затем саму матрицу.
Также в начале мейна напиши
C++
1
setlocale(LC_ALL,"")
для корректного отображения русского языка
и в конце поставь
C++
1
2
system("pause");
    return 0;
Миниатюры
Осуществить циклический сдвиг элементов квадратной  
2
1 / 1 / 0
Регистрация: 04.11.2013
Сообщений: 47
18.01.2014, 04:16  [ТС]
Да спасибо) всё работает
0
176 / 144 / 70
Регистрация: 01.05.2012
Сообщений: 414
18.01.2014, 04:18
И ещё можно так сдвиг сделать) с использованием STL
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
 if (a==1)
    {
        n=n%N;
        n=N-n;
        if (n)
            rotate(A.begin(),A.begin()+n,A.end());
    }
    else
    if (a==2)
        {
            n=n%M;
            n=M-n;
            if (n)
            for (int i=0; i<N; i++)
                 rotate(A[i].begin(),A[i].begin()+n,A[i].end());
        }
Для учебного заведения, наверно, лучше решение без использования STL.
Мне, например, когда начинал изучать С++ преподаватель не разрешал использовать STL.
1
1 / 1 / 0
Регистрация: 04.11.2013
Сообщений: 47
18.01.2014, 04:41  [ТС]
Цитата Сообщение от _script_ Посмотреть сообщение
И ещё можно так сдвиг сделать) с использованием STL
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
 if (a==1)
    {
        n=n%N;
        n=N-n;
        if (n)
            rotate(A.begin(),A.begin()+n,A.end());
    }
    else
    if (a==2)
        {
            n=n%M;
            n=M-n;
            if (n)
            for (int i=0; i<N; i++)
                 rotate(A[i].begin(),A[i].begin()+n,A[i].end());
        }
Для учебного заведения, наверно, лучше решение без использования STL.
Мне, например, когда начинал изучать С++ преподаватель не разрешал использовать STL.
Характеристикой строки целочисленной матрицы назовем сумму ее положительных четных элементов. Переставляя строки заданной матрицы, расположить их в соот-ветствии с ростом характеристик.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.01.2014, 04:41
Помогаю со студенческими работами здесь

Осуществить циклический сдвиг элементов
Осуществить циклический сдвиг элементов квадратной матрицы на n элементов вправо или вниз (в зависимости от введенного режима), n может...

Осуществить циклический сдвиг массива на N элементов
Осуществить циклический сдвиг массива на N элементов, направление указывает пользователь. Была идея как осуществить, но начать...

Осуществить циклический сдвиг элементов массива
Здравствуйте! Имеется задача: &quot;Дан массив размера N и число k (0 &lt; k &lt; 5, k &lt; N). Осуществить циклический сдвиг элементов массива влево на...

Осуществить циклический сдвиг элементов прямоугольной матрицы
Задание. Задания этого семинара соответствуют приведенным в Учебнике на с. 139. Рекомендуется выполнять каждое задание в двух вариантах:...

Осуществить циклический сдвиг элементов прямоугольной матрицы
Здравствуйте, было задание Осуществить циклический сдвиг элементов прямоугольной матрицы на п элементов вправо или вниз (в зависимости...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru