Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.95/1112: Рейтинг темы: голосов - 1112, средняя оценка - 4.95
 Аватар для Lyric
1 / 1 / 0
Регистрация: 01.02.2009
Сообщений: 4
1

Сортировка двумерного массива по возрастанию

07.02.2009, 02:36. Показов 201699. Ответов 26
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите, пожалуйста с задачей.
Необходимо отсортировать двумерный массив по возрастанию (не переводя его в одномерный).

Должно получиться примерно так:
0 0 1 1
2 3 4 5
7 8 9 9

С помощью одномерного массива - у меня получилось. А как без него не представляю даже:'(
1
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.02.2009, 02:36
Ответы с готовыми решениями:

Сортировка строк двумерного массива по возрастанию значений первого столбца
Люди добрые помогите, пожалуйста! Суть задачи такова: 1. Создать двумерный массив 2....

Сортировка массива: сначала положительные по возрастанию, потом отрицательные по возрастанию
Пользователь вводит массив чисел,нужно отсортировать его методом выбора,что бы сначала шли...

Ошибка при сортировке двумерного массива по возрастанию
По убыванию сортировка работает полноценно,а по возрастанию первое число НЕ понимаю откуда...

Упорядочить строки двумерного массива по возрастанию их наибольших элементов.
Нужно упорядочить его строки по возрастанию их наибольших элементов. #include "stdafx.h"...

26
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
16.06.2013, 15:03 21
Author24 — интернет-сервис помощи студентам
полазейте по похожей ветке
Сортировка массивов методом пузырька, вставки и быстрым способом
особенно пост #20 посмотрите
0
517 / 409 / 188
Регистрация: 08.04.2013
Сообщений: 1,748
16.04.2017, 15:45 22
Вроде работает на указателях
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <cstdlib>
#include <iomanip>
 
using namespace std;
 
void sort (int *, int row, int col);// сортирует только строки
void print(int *, int row, int col);
void sortAll (int *p, int row, int col); // сортирует массив целиком на указателях
 
int main()
{
    int row = 5, col =10;
    int mas[row][col];
    int *p = &mas[0][0];
 
  for (int i = 0; i < row*col; ++i)
    *(p + i) = (rand ()%100);
 
    print( p, row, col);
     cout << endl;
 
 // for (int i = 0; i < row; ++i ) // сортирует только строки
 //     sort( p, i, col);
 
 sortAll( p, row, col);
 
    print( p, row, col);
  return 0;
}
 
void sort (int *p, int row, int col)
{
      int N = row*col;
        for (int j = 0; j < col-1; ++j) {
            for (int k = 0; k < col-1; ++k) {
                if ( *(p+N+k) > *(p+N+k+1)) {
                int temp=*(p+N+k); *(p+N+k)=*(p+N+k+1);*(p+N+k+1)=temp;
                }
            }
        }
}
 
void print (int *p, int row, int col) {
   int N = row*col;
   for (int i = 0; i < N; i++)
    {
        if(!(i%col)) cout <<endl;
        cout << setw (3) << *(p + i);
    }
}
 
void sortAll (int *p, int row, int col)
{
      int N = row*col;
        for (int i = 0; i < N; ++i) {
            for (int j = 0; j < N; ++j) {
                if ( *(p+i) < *(p+j)) {
                int temp=*(p+i); *(p+i)=*(p+j);*(p+j)=temp;
                }
            }
        }
}
0
0 / 0 / 0
Регистрация: 16.01.2018
Сообщений: 1
16.01.2018, 18:44 23
Спасибо, помогло. Самое быстрое решение.
0
0 / 0 / 0
Регистрация: 05.04.2018
Сообщений: 1
05.04.2018, 10:44 24
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
#include<iostream>
using namespace std;
int main()
{
 
    setlocale(LC_ALL, "rus");
    const int n = 5;
    const int m = 4;
    int Arr[n][m];
    //Заполняем массив случайными числами
 for (int i = 0; i < n; i++) 
    {
        for (int j = 0; j < m; j++)
        {
            Arr[i][j] = rand()%100;
        }
    }
 //Выводим массив до сортировки на экран
        for (int i = 0; i < n; i++)
        {
            for (int j = 0; j < m; j++)
            {
                cout << Arr[i][j] << "\t";
            }
            cout << endl;
        }
        //Сортировка двумерного массива
            for (int k = 0; k < n; k++)
            {
                for (int r = 0; r < m; r++)
                {
                    for (int i = 0; i < n; i++)
                    {
 
                        for (int j = 0; j < m; j++)
                        {
 
                            if (Arr[i][j] > Arr[k][r])
                            {
                                int Temp = Arr[i][j];
                                Arr[i][j] = Arr[k][r];
                                Arr[k][r] = Temp;
                            }
                        }
                    }
                }
            }
            cout << "_______________________________" << endl;
            //Выводим отсортированый массиыв
 
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < m; j++)
                {
                    cout << Arr[i][j] << "\t";
                }
                cout << endl;
            }
    cout << endl;
    }
0
0 / 0 / 0
Регистрация: 12.07.2018
Сообщений: 7
12.07.2018, 17:41 25
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<time.h>
 
/*Создайте двухмерный массив. Заполните его случайными числами и покажите на экран. Выполните сортировку массива. Полученный результат покажите на экран.
Пример: пусть у нас есть массив
2 8 4 
0 1 9 
7 8 3
4 5 6
После сортировки получим:
0 1 2
3 4 4
5 6 7
8 8 9
 
*/
 
using namespace std;
 
int main() {
    srand(time(0));
    setlocale(LC_ALL, "ru");
    const int row = 3, col = 5;
    int mas[row][col];
 
    for (int i = 0; i < row; i++)
    {
        for (int j = 0; j < col; j++)
        {
            mas[i][j] = rand() % 100;
            cout << mas[i][j] << "\t";
        }
        cout << endl;
    }
    cout << endl;
    for (int i = 0; i < row*col - 1; i++)
    {
        for (int i = 0, j = 0; j < row*col - 1; j++)
        {
            if (mas[i][j] > mas[i][j + 1]) {
                int tmp = mas[i][j];
                mas[i][j] = mas[i][j + 1];
                mas[i][j + 1] = tmp;
            }
        }
    }
    for (int i = 0; i < row; i++)
    {
        for (int j = 0; j < col; j++)
        {
            cout << mas[i][j] << "\t";
        }
        cout << endl;
    }
    cin.get(); cin.get();
}
0
0 / 0 / 0
Регистрация: 20.07.2022
Сообщений: 1
28.09.2022, 23:44 26
Лучший!!!
0
0 / 0 / 0
Регистрация: 16.11.2022
Сообщений: 1
16.11.2022, 17:44 27
Как по мне, это самый простой и понятный способ сортировки двумерного массива:
C++
1
2
3
4
5
6
7
8
9
10
for (int i = 0; i < max; i++)
    for (int j = 0; j < max; j++)
        for (int h = 0; h < max; h++)
            for (int g = 0; g < max; g++)
                if (mas[i][j] < mas[h][g])
                {
                    float buf = mas[h][g];
                    mas[h][g] = mas[i][j];
                    mas[i][j] = buf;
                }
Чтобы отсортировать по убыванию, нужно в if'е поменять "<" на ">"
0
16.11.2022, 17:44
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.11.2022, 17:44
Помогаю со студенческими работами здесь

Как отсортировать столбцы двумерного массива по возрастанию (по сумме столбцов)?
Не понимаю, алгоритма сортировки, пожалуйста помогите

Упорядочить по возрастанию все строки двумерного массива, которые неупорядочены по убыванию
как упорядочить по возрастанию все строки двумерного массива, которые неупорядочены по убыванию....

Как составить функцию для отсортировки столбцов двумерного массива по возрастанию ?
Вообще не понимаю принцип действия такой сортировки, кто может помочь и объяснить?

Сортировка двумерного массива
Input sample: 4 10 20 30 7 30 00 23 59 59 13 30 30 Output sample: 7 30 0 10 20 30


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

Или воспользуйтесь поиском по форуму:
27
Ответ Создать тему
Новые блоги и статьи
Информационные технологии
hw_wired 28.01.2025
Введение в современные технологии работы с информацией В современном мире информационные технологии стали неотъемлемой частью практически всех сфер человеческой деятельности. Они существенно. . .
Информация вокруг нас
hw_wired 28.01.2025
Основные понятия информации В современном мире понятие информации является фундаментальным и охватывает практически все сферы человеческой деятельности. Информация представляет собой совокупность. . .
Компьютер для начинающих
hw_wired 28.01.2025
Введение в мир компьютерных технологий В современном мире информация стала одним из важнейших ресурсов человечества, определяющим развитие общества и технологий. Наша жизнь неразрывно связана с. . .
[golang] 189. Rotate Array
alhaos 28.01.2025
Повороты рукоятки, целочисленный слайс нужно сдвинуть на целое положительное число. Мне очень нравится решение на GO / / https:/ / leetcode. com/ studyplan/ top-interview-150/ package topInterview . . .
КуМир: решение задач на матрицы
bytestream 28.01.2025
КуМир представляет собой среду для обучения программированию, которая включает в себя мощные инструменты для работы с матрицами. Матрица в программировании - это двумерный массив, состоящий из. . .
КуМир: решение задач на строки
bytestream 28.01.2025
В системе программирования КуМир работа со строковыми данными является одним из важнейших аспектов создания программ. Строки представляют собой последовательности символов, заключенные в кавычки,. . .
КуМир: решение геометрических задач
bytestream 28.01.2025
Программирование геометрических задач в среде КуМир становится всё более актуальным в обучении школьников и студентов. КуМир — это разработанная в России обучающая программная среда, предназначенная. . .
КуМир, исполнитель Водолей: Задачи и решения
bytestream 28.01.2025
КуМир — это образовательная среда для обучения программированию. Она предлагает пользователям разнообразные инструменты для разработки и отладки программ, что особенно ценно для студентов и. . .
КуМир, исполнитель Чертежник: Решение задач
bytestream 28.01.2025
КуМир (Комплект Учебных МИРов) представляет собой образовательную среду для обучения основам программирования и алгоритмизации. Исполнитель Чертежник работает на координатной плоскости, где может. . .
Rust или Go? А может C++?
hw_wired 28.01.2025
С каждой новой технологией или методологией появляются новые языки программирования, призванные решать конкретные задачи либо улучшать аспекты производительности и безопасности. Среди множества. . .
Fortran и WinAPI: как создать приложение с графическим интерфейсом
hw_wired 28.01.2025
Fortran — это один из старейших высокоуровневых языков программирования, широко используемый в науке и инженерии уже несколько десятилетий. Его название происходит от "Formula Translation" (перевод. . .
Списки в Haskell
hw_wired 28.01.2025
Haskell является функциональным языком программирования, который отличается лаконичностью синтаксиса и мощными абстракциями. Важным концептом в Haskell являются списки — упорядоченные коллекции. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru