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

Отсортировать заданный массив по столбцам

03.01.2016, 16:17. Показов 7959. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!
Суть задачи: создать массив, ввести построчно элементы массива и отсортировать полученный массив по столбцам. Вся проблема с последним пунктом.
Вот, что вышло пока:
C++ (Qt)
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
#include <conio.h>
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
    setlocale(LC_ALL, "rus");
    int k, l;
    int a[100][100];
    cout << "Количество строк - ";
    cin >> k;
    cout << "Количество столбцов - ";
    cin >> l;
    //Заполнаяем массив
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
        {
            cout << "Введите [" << i << "][" << j << "] элемент‚:  ";
            cin >> a[i][j];
        }
    }
 
    cout << endl << "   Матрица [" << k << "x" << l << "]:" << endl << endl;
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
            cout << setw(5) << a[i][j];
        cout << endl;
    }
 
    cout << endl;
 
 
 
 
    return 0;
}
Сортировка построчно выходит, а столбцами нет.
Прошу помощи.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.01.2016, 16:17
Ответы с готовыми решениями:

Отсортировать двумерный массив по столбцам
Добрый день! Я хочу отсортировать двухмерный масив по колоннам! Вот код программы -&gt; #include &lt;bits/stdc++.h&gt; ...

Отсортировать двумерный массив по столбцам
С помощью какой сортировки можно отсортировать двумерный массив по столбцово? Следующий вопрос вот в чем. Вот у меня двумерный массив (3...

Отсортировать заданный целочисленный массив при помощи сортировки выбором (selection sort)
Напишите пожалуста простенькие программы на подобие этой: #include &lt;iostream&gt; using namespace std; void main () { const int...

14
 Аватар для _Valera_
495 / 377 / 136
Регистрация: 27.01.2015
Сообщений: 1,588
03.01.2016, 16:20
Цитата Сообщение от SugarUnicorn Посмотреть сообщение
Сортировка построчно выходит, а столбцами нет.
Я не вижу тут никакой сортировки, и попыток тоже
0
0 / 0 / 0
Регистрация: 13.02.2015
Сообщений: 13
03.01.2016, 19:34  [ТС]
Прошу прощения, не все скинул.
Код:
C++ (Qt)
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
#include <conio.h>
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
    setlocale(LC_ALL, "rus");
    int k, l, m;
    int a[100][100];
    int p[100][100];
    cout << "Количество строк - ";
    cin >> k;
    cout << "Количество столбцов - ";
    cin >> l;
    //Заполнаяем массив
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
        {
            cout << "Введите [" << i << "][" << j << "] элемент‚:  ";
            cin >> a[i][j];
        }
    }
 
    cout << endl << "   Матрица [" << k << "x" << l << "]:" << endl << endl;
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
            cout << setw(5) << a[i][j];
        cout << endl;
    }
 
    for (int i=0;i<k;i++)
    {
        for(int j=0;j<l;j++)
        {
            for (int k=l-1;k>j;k--)
                if (a[i][k]<a[i][k-1])
                {
                    int tmp=a[i][k];
                    a[i][k]=a[i][k-1];
                    a[i][k-1]=tmp;
                }
            cout<<a[i][j]<<" ";
        }
        cout <<"\n";
    }
 
 
    cout << endl;
 
    return 0;
}
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
03.01.2016, 19:48
SugarUnicorn, По столбцам.
C++
1
2
3
4
5
6
7
8
9
10
11
12
for( int i = 0; i < k; i++ ) {
    for( int j = 0; j < l; j++ ) {
        if( i != 0 )
            if( a[i][j] > a[i][j-1] ) {
                int tmp = a[i][j];
                a[i][j] = a[i][j-1];
                a[i][j-1] = tmp;
            }
        cout << a[i][j] << " ";
    }
    cout << endl;
}
0
0 / 0 / 0
Регистрация: 13.02.2015
Сообщений: 13
03.01.2016, 19:54  [ТС]
Цитата Сообщение от makfak Посмотреть сообщение
По столбцам.
Спасибо, но в данном варианте в начальном массиве первую строку оставляет как было, все остальные заполняет нулями.
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
03.01.2016, 20:03
SugarUnicorn, В строке 4 символ > замените на <.

Добавлено через 3 минуты
Короче вот так.
C++
1
2
3
4
5
6
7
8
9
10
11
for( int i = 0; i < k; i++ ) {
    for( int j = 0; j < l; j++ ) {
            if( a[i][j+1] < a[i][j] ) {
                int tmp = a[i][j+1];
                a[i][j+1] = a[i][j];
                a[i][j] = tmp;
            }
        cout << a[i][j] << " ";
    }
    cout << endl;
}
0
0 / 0 / 0
Регистрация: 13.02.2015
Сообщений: 13
03.01.2016, 20:08  [ТС]
Цитата Сообщение от makfak Посмотреть сообщение
Короче вот так.
Теперь первый столбец содержит значения, второй пуст.
Т.е. из массива:
4 7
1 5
8 2
Получаем:
4 0
1 0
2 0
Как решить, не знаю.
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
03.01.2016, 21:01
SugarUnicorn, Радуйтесь, только возьмите последние строки, я использовал рандом для заполнения массива, чтобы не приходилось делать это вручную.
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
#include <conio.h>
#include <iostream>
#include <iomanip>
#include <random>
#include <ctime>
using namespace std;
int main()
{
    setlocale(LC_ALL, "rus");
    mt19937 gen( time( NULL ) );
    uniform_int_distribution<int> dist( -99, 99 );
    int k, l, m;
    int a[100][100];
    int p[100][100];
    cin >> k >> l;
    //Заполнаяем массив
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
        {
            a[i][j] = dist( gen );
        }
    }
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
            cout << setw(3) << a[i][j];
        cout << endl;
    }
    cout << "\n\n";
 
    for( int i = 0; i < k; i++ ) {
        for( int j = 0; j < l-1; ++j ) {
            for( int k = 0; k < l-1; ++k ) {
                if( a[i][k+1] < a[i][k] ) {
                    int tmp = a[i][k+1]; 
                    a[i][k+1] = a[i][k]; 
                    a[i][k] = tmp;
                }
            }
            //cout << setw(3) << a[i][j];
        }
    }
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
            cout << setw(3) << a[i][j];
        cout << endl;
    }
    return 0;
}
0
0 / 0 / 0
Регистрация: 13.02.2015
Сообщений: 13
03.01.2016, 23:53  [ТС]
Цитата Сообщение от makfak Посмотреть сообщение
Радуйтесь
Спасибо, конечно, но этот вариант сортировки по строке
Наверное, не правильно выразил суть проблемы:
Цитата Сообщение от SugarUnicorn Посмотреть сообщение
отсортировать полученный массив по столбцам
, т.е. отсортировать каждый столбец.

Добавлено через 2 часа 34 минуты
В общем, логика примерна понятна, но вот с реализацией никак.
Должно быть что-то вроде такого:
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
for (int i=0;i<k;i++)
    {
        for(int j=0;j<k-1;j++)
        {
            for (int m=0;m<k;m++)
                if (a[j][m]<a[j+1][m])
                {
                    int tmp=a[j][m];
                    a[j][m]=a[j+1][m];
                    a[j+1][m]=tmp;
                }
            for (int i=0; i<k; i++)
            {
                for(int j=0; j<l; j++)
                    cout << setw(5) << a[i][j];
                cout << endl;
Но вот нифига.
0
4 / 4 / 6
Регистрация: 14.10.2015
Сообщений: 26
04.01.2016, 01:07
SugarUnicorn, если вы про транспонированную матрицу, то вот решение:
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
#include <conio.h>
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
    setlocale(LC_ALL, "rus");
    int k, l;
    int a[100][100];
    cout << "Количество строк - ";
    cin >> k;
    cout << "Количество столбцов - ";
    cin >> l;
    //Заполнаяем массив
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
        {
            cout << "Введите [" << i << "][" << j << "] элемент‚:  ";
            cin >> a[i][j];
        }
    }
    cout << endl << "   Матрица [" << k << "x" << l << "]:" << endl << endl;
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
            cout << setw(5) << a[i][j];
        cout << endl;
    }
    cout << endl;
    cout << "отсортированная матрица" << endl;\
    cout << endl << "   Матрица [" << k << "x" << l << "]:" << endl << endl;
    for (int i=0; i<k; i++)
    {
        for(int j=0; j<l; j++)
            cout << setw(5) << a[j][i];
        cout << endl;
    }
    cout << endl;
    return 0;
}
1
0 / 0 / 0
Регистрация: 13.02.2015
Сообщений: 13
04.01.2016, 06:49  [ТС]
транспонированную
Нет, не то.
Задание в методичке такое: Дан двумерный массив. Заполнить его по строкам с клавиатуры и отсортировать каждый столбец по убыванию.
Т.е.:
было --- стало
1 5 --- 3 7
2 6 --- 2 6
3 7 --- 1 5
0
518 / 410 / 188
Регистрация: 08.04.2013
Сообщений: 1,750
04.01.2016, 09:40
Лучший ответ Сообщение было отмечено SugarUnicorn как решение

Решение

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
//строка двумерного массива пузырьковая для столбцов
#include <iostream>
#include <windows.h>
#include <ctime>
#define SZ 5
 
using namespace std;
 
int main(int argc, char* argv[])
 
{   int a[SZ][SZ];   //Двумерный Массив поконстанте*
    int n;  //а*§¬Ґа Їа®ўҐаאַ© ¬*ваЁжл
    int i,j; //Ё*¤ҐЄбл ¬*ббЁў*
    int k;
    int temp;
    time_t t;
    
    srand((unsigned)time(&t));
n=SZ;   
// заполняем и выводим массив
    for ( i= 0; i<n; i++)   {  
      cout <<endl;
      for ( j = 0; j<n; j++) {
        a[i][j] =(rand ()%10);
        cout.width (4);
        cout <<a[i][j];
        }
    }
    cout << endl;
//для каждой столбца сортировка пузырьковая    
 
    for ( j = 0; j<n; j++){
    
        for ( i = 0; i<n-1; i++) {
            for ( k = 0; k<n-1; k++) {
                if(a[k][i] < a[k+1][i]) {
                    temp=a[k][i]; a[k][i]=a[k+1][i];a[k+1][i]=temp;
                } 
            }
        }
    }       
 
// Вывод массива после
    for ( i= 0; i<n; i++)   {  
        cout <<endl;
    for ( j = 0; j<n; j++) {
        cout.width (4);
        cout <<a[i][j];
        }
    }
    cout <<endl;
 
   system("PAUSE"); 
   return 0;
    
}
Добавлено через 2 минуты
найди разницу для строк
C++
1
2
3
4
5
6
7
8
9
10
11
12
//для каждой строки сортировка пузырьковая  
 
    for ( i = 0; i<n; i++){
    
        for ( j = 0; j<n-1; j++) {
            for ( k = 0; k<n-1; k++) {
                if(a[i][k] < a[i][k+1]) {
                    temp=a[i][k]; a[i][k]=a[i][k+1];a[i][k+1]=temp;
                } 
            }
        }
    }
1
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
04.01.2016, 12:19
SugarUnicorn, Столбцы, в моём представлении - это вертикальные линии, по ним и идёт сортировка, а остальное как вы просто выберите, если хотите отсортировать по-другому, то просто замените буквы i и j местами в циклах.
1
0 / 0 / 0
Регистрация: 13.02.2015
Сообщений: 13
04.01.2016, 14:51  [ТС]
Спасибо парни, все верно выполняется!
Цитата Сообщение от marat_miaki Посмотреть сообщение
for ( i = 0; i<n-1; i++)
Только здесь надо, как мне кажется, i <= n-1, иначе последний столбец не сортирует.
Все круто, благодарю.
0
518 / 410 / 188
Регистрация: 08.04.2013
Сообщений: 1,750
04.01.2016, 15:04
точнее
C++
1
34 for ( i = 0; i<n; i++)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.01.2016, 15:04
Помогаю со студенческими работами здесь

Массив: Отсортировать полученный массив 3 способами: по строкам, по столбцам( возр.), 3) и весь массив
Помогите, пожалуйста ,решить задачу. Очень нужно. Задан массив (4*6). Элементы задаются по правилу: если j&gt;3, то Aij=i+j, иначе...

Массив: Отсортировать двумерный массив по строкам и столбцам
Помогите! Дали задачу по программированию на бейсике, но у меня как-то с этим не заладилось.Задача такая - Отсортировать двумерный массив...

Отсортировать двумерный массив (m,n) из рандомных чисел по строкам и столбцам линейно
Как ?

Отсортировать заданный массив по убыванию
Задача: Отсортировать заданный массив целых чисел А(I) в порядке убывания их значений. I=1,2,....,10. Значит написал я код, хотел сделать...

Массив: Вычислить сумму элементов по столбцам и отсортировать матрицу в зависимости этой суммы
Доброго всем времени суток. Ребят столкнулся с проблемой,задали написать программу! Написать программу, которая вводит по строкам с...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
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