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

Отсортировать матрицы от меньшего к большему методом пузырька

15.03.2014, 21:46. Показов 1697. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Надо отсортировать массив от меньшего к большему методом пузырька, проблема заключается в том, что я сделал сортировку, но сортируется только в отдельных строках, не могу понять как весь массив отсортировать. Помогите.

Добавлено через 20 минут
Можно какой-то наводящий ответ, или подсказку.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.03.2014, 21:46
Ответы с готовыми решениями:

Отсортировать массив от меньшего к большему по дате и в следующем массиве от меньшего к большему по id
Ещё раз здрасте всем, как отсортировать такого типа ассоциативный массив.. от меньшего к большему по дате и в следущем массиве от...

Метод пузырька: вывести в Memo отсортированный массив от меньшего к большему
Есть текстовый файл, в котором находится массив чисел. Каждое число в новой строке. Количество чисел в массиве неизвестно. Написать...

Отсортировать массив от меньшего к большему
Помогите отсортировать Mas2; #include <stdio.h> #include <conio.h> #include <math.h> int main(){ int...

5
 Аватар для fishec
126 / 125 / 62
Регистрация: 07.09.2013
Сообщений: 343
15.03.2014, 21:51
Тут для примера массив 3 на 3.
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 <iostream>
using namespace std;
int main()
{
    const int n = 3;
    const int m = 3;
    int arr[n][m] = {3,1,4,2,9,6,8,7,5};
    cout << "Array: " << endl;
    for (int i = 0; i < n; ++i){
        for (int j = 0; j < m; ++j)
            cout << arr[i][j] << " ";
        cout << endl;
    }
    int size = sizeof(arr) / sizeof(int);
    
 
    //Сортировка///////////////////////////////////
    for (int i = 0; i < n*m-1; ++i){
        bool Sorted = true;
        for (int j = i; j < n*m-1; ++j){
            if (arr[(j + 1) / n][(j + 1) % n] < arr[j / n][j%m]){
                int tmp = arr[(j + 1) / n][(j + 1) % n];
                arr[(j + 1) / n][(j + 1) % n] = arr[j / n][j%m];
                arr[j / n][j%m] = tmp;
                Sorted = false;
            }
        }
        if (Sorted) break;
    }
    ///////////////////////////////////////////////
 
 
    cout << "Sorted Array: " << endl;
    for (int i = 0; i < n; ++i){
        for (int j = 0; j < m; ++j)
            cout << arr[i][j] << " ";
        cout << endl;
    }
    system("pause");
    return 0;
}
1
196 / 197 / 120
Регистрация: 27.05.2011
Сообщений: 545
15.03.2014, 21:53
А код можно? Я не понимаю, что значит
Цитата Сообщение от Kolbusdkiy Посмотреть сообщение
но сортируется только в отдельных строках
. И по-подробнее можно, по какому принципу нужно отсортировать двухмерный масив?
0
 Аватар для fishec
126 / 125 / 62
Регистрация: 07.09.2013
Сообщений: 343
15.03.2014, 21:57
Цитата Сообщение от mymedia Посмотреть сообщение
по какому принципу нужно отсортировать двухмерный масив?
я так понимаю, что из массива
4 2
3 1
должен получится
1 2
3 4
А у ТС получается
2 4
1 3
0
 Аватар для Kolbusdkiy
0 / 0 / 1
Регистрация: 14.10.2013
Сообщений: 112
15.03.2014, 22:11  [ТС]
mymedia, ну вот, например у меня такой массив:
2 9 6 5
1 4 0 9
6 8 7 5
а нужно сделать вот такой:
0 1 2 4
5 5 6 6
7 8 9 9

Добавлено через 1 минуту
Вот мой код:
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 <stdlib.h>
#include <time.h>
using namespace std;
 
void bubbleSort(int *, int);
int kilk(int** Arr, int m, int n);
void num(int** Arr,int m, int n);
 
int** made(const int nstr, const int nstb){
    int** mas = new int*[nstr];
    for (int i=0; i<nstr; i++)
        mas[i] = new int[nstb];
    cout<<"Array is created.\n";
return mas;
}
 
void dell(int** mas, const int nstr, const int nstb){
    for (int i=0; i<nstr; i++)
        delete[]mas[i];
    delete[]mas;
    cout<<"Array is deleted";
}
 
void read(int** mas, const int nstr,const int nstb){
    srand (time(0));
    for(int i=0; i<nstr; i++)
        for(int j=0; j<nstb; j++)
            mas[i][j]=rand()%10-7;
}
 
void Print_array(int** mas, const int nstr, const int nstb){
    for(int i=0; i<nstr; i++){
        for(int j=0; j<nstb; j++)
            cout<<mas[i][j]<<' ';
        cout<<endl;
    }
}
 
bool funArray(int* mas, const int nel){
    bool d=false;
    for(int i=0; i<nel; i++)
        if(mas[i]>0 && mas[i]%2==0) 
            d=true;
    
    return d;
}
 
int main(){
    int n,m;
    cout<<"Size array: ";
    cin>>n>>m; 
    int **Arr=made(n,m);
    read(Arr,n,m);
    Print_array(Arr,n,m);
    
    for(int k=0; k<m; k++)
        bubbleSort(Arr[k],n);
    cout<<endl;
    Print_array(Arr,n,m);
    dell(Arr,n,m);
}
 
void bubbleSort(int* arr, int n) {
    int temp = 0; 
    bool exit = false; 
    
    while (!exit) {
        exit=true;
        for (int i=0; i < (n-1); i++)
            
            if (arr[i] > arr[i + 1]) {
                temp = arr[i];
                arr[i] = arr[i + 1];
                arr[i + 1] = temp;
                exit = false;
            }
    }
}





Добавлено через 11 минут
fishec, можешь объяснить саму сортировку поподробнее?
0
 Аватар для fishec
126 / 125 / 62
Регистрация: 07.09.2013
Сообщений: 343
15.03.2014, 22:31
Здесь обычный пузырек, как у тебя. Просто индексы элементов считаются от общего порядкового номера.
Например, в матрице
https://www.cyberforum.ru/cgi-bin/latex.cgi?\begin{bmatrix}5 & 3 &4 \\ 2 & 9 &1 \\ 7 &6  &8 \end{bmatrix}
нумеруем числа по порядку от 0 до 8. (то есть от 0 до (n*m-1), где n и m -размеры матрицы)
То есть у числа 5 будет номер 0. У числа 2 - номер 3, у числа 6 - номер 7. (то есть получается общая нумерация, и фактически работаем с матрицей, как с обычным одномерным массивом).
Но чтобы например, обратиться в матрице к элементу с общим номером 7(то есть к числу 6), нужно написать a[2][1], то есть a[7/3][7%3].
В выражении arr[j / n][j%m] из общего номера j считаем номер строки и столбца в матрице.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.03.2014, 22:31
Помогаю со студенческими работами здесь

Отсортировать двухмерный массив, от меньшего к большему
помогите пожалуйста отсортировать двухмерный массив, от меньшего к большему. Спасибо за ранее

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

Написать программу, которая должна отсортировать 5 чисел от меньшего к большему
Написать программу, которая должна отсортировать 5 чисел от меньшего к большему. То есть, она должна отсортировать массив от меньшего к...

Отсортировать вектор типа char (от меньшего кол-ва символов в слове к большему и наоборот)
Подскажите, как отсортировать вектор типа char (от меньшего кол-ва символов в слове к большему и наоборот)

Дана строка символов ( вводится через TEdit ). Её надо отсортировать ( от меньшего к большему ) и вывести в Label.
Дана строка символов ( вводится через TEdit ). Её надо отсортировать ( от меньшего к большему ) и вывести в Label. procedure...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru