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

Сортировка двумерного массива - C++

Восстановить пароль Регистрация
 
KyKi
3 / 3 / 0
Регистрация: 12.09.2013
Сообщений: 129
22.10.2013, 20:28     Сортировка двумерного массива #1
Задача:
Написать код сортировки двумерного массива размерностью m*n.
Переставить строки матрицы так, чтобы элементы k-го столбца были отсортированы по неубыванию с помощью прямого выбора.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.10.2013, 20:28     Сортировка двумерного массива
Посмотрите здесь:

Сортировка двумерного массива C++
сортировка двумерного массива C++
сортировка двумерного массива C++
сортировка двумерного массива C++
Сортировка двумерного массива... C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Folko
 Аватар для Folko
265 / 253 / 7
Регистрация: 27.09.2013
Сообщений: 877
Записей в блоге: 1
22.10.2013, 20:51     Сортировка двумерного массива #2
KyKi, код есть?
KyKi
3 / 3 / 0
Регистрация: 12.09.2013
Сообщений: 129
22.10.2013, 21:02  [ТС]     Сортировка двумерного массива #3
Цитата Сообщение от Folko Посмотреть сообщение
KyKi, код есть?
В том-то и дело,что не знаю с чего начать(никак с этой сортировкой не разберусь(
подскажите пожалуйста,с чего хоть начать??
Folko
 Аватар для Folko
265 / 253 / 7
Регистрация: 27.09.2013
Сообщений: 877
Записей в блоге: 1
22.10.2013, 21:12     Сортировка двумерного массива #4
KyKi, это всегда пожалуйста) Сделайте для начала создание произвольной матрицы NxM (вводим значения n и m, по ним создаем динамический двумерный массив и заполняем его значениями), затем функцию обмена двух строк (я бы сделал ее, но некоторые предпочтут прямо в теле программы менять)

Добавлено через 7 минут
KyKi, затем узнаем номер нужного столбца (k) и работаем только с ним. Вместо обмена 2 значений мы производим обмен 2 строк с помощью уже созданной функции. Вот в принципе и вся задача) та же сортировка
KyKi
3 / 3 / 0
Регистрация: 12.09.2013
Сообщений: 129
22.10.2013, 21:15  [ТС]     Сортировка двумерного массива #5
Цитата Сообщение от Folko Посмотреть сообщение
KyKi, это всегда пожалуйста) Сделайте для начала создание произвольной матрицы NxM (вводим значения n и m, по ним создаем динамический двумерный массив и заполняем его значениями), затем функцию обмена двух строк (я бы сделал ее, но некоторые предпочтут прямо в теле программы менять)

Добавлено через 7 минут
KyKi, затем узнаем номер нужного столбца (k) и работаем только с ним. Вместо обмена 2 значений мы производим обмен 2 строк с помощью уже созданной функции. Вот в принципе и вся задача) та же сортировка
ну с вводом значений понятно)можно по подробнее про обмен 2 строк и функции для этого??)
Angeline
36 / 30 / 2
Регистрация: 21.10.2013
Сообщений: 197
22.10.2013, 21:18     Сортировка двумерного массива #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
#include <stdio.h>
#include <stdlib.h>
void main()
{
    int matrica[100][100];
    int servmass[100];
    int i;
    int j;
    int k;
    int servp;
    int min;
    for  (i=0; i<100; i++)
    {
        for (j=0; j<100; j++)
            matrica[i][j]=rand()%100;
    }
min=matrica[0][0];
scanf("%d", &k);
for (i=1; i<100; i++)
{
    if (matrica[i][k]<min) 
    {
        for (j=0; j<100; j++)
        {
            servmass[j]=matrica[i-1][j];
            matrica[i-1][j]=matrica[i][j];
            matrica[i][j]=servmass[j];
        }
    }
}
}
Folko
 Аватар для Folko
265 / 253 / 7
Регистрация: 27.09.2013
Сообщений: 877
Записей в блоге: 1
22.10.2013, 21:24     Сортировка двумерного массива #7
KyKi, что то типа этого
C++ (Qt)
1
2
3
4
5
6
7
8
9
void swap_line (int **arr, int m, int a, int b)
{
    for (int i = 0; i < m; i++)
    {
        int temp = arr[a][i];
        arr[a][i] = arr[b][i];
        arr[b][i] = temp;
    }
}
Передается ссылка на дин массив, величина строки, a - b номера строк, которые нужно обменять. Писал ее для обмена столбцов, но вроде изменил корректно. Потестите перед применением

Добавлено через 3 минуты
Angeline, вы так в будущем не замахивайтесь на servmass[100]. Даже если строки будут по 1000 ячеек, для обмена хватит 1 переменной
Angeline
36 / 30 / 2
Регистрация: 21.10.2013
Сообщений: 197
22.10.2013, 21:33     Сортировка двумерного массива #8
Folko, поняла, спасибо, учту. И правда надо было еще один цикл сделать просто.
KyKi
3 / 3 / 0
Регистрация: 12.09.2013
Сообщений: 129
22.10.2013, 21:35  [ТС]     Сортировка двумерного массива #9
Вот что-то типа такого получилось..но тут явно что-то не то(кроме ввода массива вообще больше ничего не происходит(
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
#include <iostream>
using namespace std;
 
    int main()
{
    setlocale (LC_ALL,"Russian");
    const int m=5;
    const int n=6;
    int mas[m][n]; 
    int i,j,x,k,min;
    for(i=0;i<m;i++)   
    {    
        for(j=0;j<n;j++)
         {
            cout<<"\n До сортировки"<<endl;
            cin>>mas[i][j];
         }
        min=mas[0][0];
        for (i=0; i<m; i++)
        {
            if (mas[i][j]<min)
            {
                for (j=0;j<n;j++)
                {
                    x=mas[i-1][j];
                    mas[i-1][j]=mas[i][j];
                    mas[i][j]=x;
                }
            }
        }
    }
    return 0;
    }
Angeline
36 / 30 / 2
Регистрация: 21.10.2013
Сообщений: 197
22.10.2013, 21:44     Сортировка двумерного массива #10
KyKi, тут кроме ввода ничего не написано, логично, что ничего не происходит. Вывод отсортированного допиши.
KyKi
3 / 3 / 0
Регистрация: 12.09.2013
Сообщений: 129
22.10.2013, 22:02  [ТС]     Сортировка двумерного массива #11
Цитата Сообщение от Angeline Посмотреть сообщение
KyKi, тут кроме ввода ничего не написано, логично, что ничего не происходит. Вывод отсортированного допиши.
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
#include <iostream>
using namespace std;
 
    int main()
{
    setlocale (LC_ALL,"Russian");
    const int m=5;
    const int n=6;
    int mas[m][n]; 
    int i,j,x,k,min;
    for(i=0;i<m;i++)   
    {    
        for(j=0;j<n;j++)
         {
            cout<<"\n До сортировки"<<endl;
            cin>>mas[i][j];
         }
        min=mas[0][0];
        for (i=0; i<m; i++)
        {
            if (mas[i][j]<min)
            {
                for (j=0;j<n;j++)
                {
                    x=mas[i-1][j];
                    mas[i-1][j]=mas[i][j];
                    mas[i][j]=x;
                }
            }
        }
    }
    cout<<mas[i][j]<<" ";
    return 0;
    }
бред сумасшедшего получается(((помогите исправить пожалуйста(

Добавлено через 16 минут
Пожаааалуйста помогите(очень нужно на завтра
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.10.2013, 01:16     Сортировка двумерного массива
Еще ссылки по теме:

C++ сортировка двумерного массива
C++ Сортировка двумерного массива
Сортировка двумерного массива C++

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

Или воспользуйтесь поиском по форуму:
Folko
 Аватар для Folko
265 / 253 / 7
Регистрация: 27.09.2013
Сообщений: 877
Записей в блоге: 1
23.10.2013, 01:16     Сортировка двумерного массива #12
KyKi, омном ном. Сейчас попробую

Добавлено через 45 минут
KyKi, типа так, но у меня работает с багами. По сути алгоритм правильный, возможно где то вкралась неточность. Надеюсь, вам поможет в решении задачи
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
54
55
56
#include <QTextStream>
 
void swap_lines(int **arr, int m, int a, int b)
{
    for (int i = 0; i < m; i++)
    {
        int temp = arr[a][i];
        arr[a][i] = arr[b][i];
        arr[b][i] = temp;
    }
}
 
int main(int argc, char *argv[])
{
    QTextStream cout(stdout);
    QTextStream cin(stdin);
    int n, m, k;
    cout << "N:" << endl;
    cin >> n;
    cout << "M:" << endl;
    cin >> m;
    cout << "K:" << endl;
    cin >> k;
    int **arr = new int*[n];
    for (int i = 0; i < n; i++)
        arr[i] = new int[m];
    cout << "Input array..." << endl;
    for (int i = 0; i < n; i++)
        for (int j = 0; j < m; j++)
        {
            cout << "arr[" << i << "][" << j << "]:" << endl;
            cin >> arr[i][j];
        }
    cout << "Array:" << endl;
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++) cout << arr[i][j] << "  ";
        cout << endl;
    }
    /*сортируем*/
    for (int i = 0; i < n; i++)
        for (int j = 0; j < n - i; j++)
            if (arr[j][k] > arr[j+1][k]) swap_lines(arr,m,j,j+1);
    /*результаты*/
    cout << "New array:" << endl;
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++) cout << arr[i][j] << "  ";
        cout << endl;
    }
    /*выход*/
    for (int i = 0; i < n; i++)
        delete []arr[i];
    delete []arr;
    return 0;
}
Yandex
Объявления
23.10.2013, 01:16     Сортировка двумерного массива
Ответ Создать тему
Опции темы

Текущее время: 14:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru