С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Azerrot
8 / 8 / 1
Регистрация: 31.12.2012
Сообщений: 47
#1

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

20.11.2013, 21:33. Просмотров 665. Ответов 4
Метки нет (Все метки)

Всем привет, я давно уже не брался за программирование и вдруг что то в голову ударило решил побаловаться проверить помню ли еще хоть что нибудь. Решил сделать сортировку двумерного массива получилось вот что

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
#include <cstdlib>
#include <iostream>
 
using namespace std;
 
int main(int argc, char *argv[])
{
    srand(time(0));
     
    int mas[10][10];
    for(int i=0; i<10; i++){
    for(int j=0; j<10; j++){
    mas[i][j] = rand()%100;                
    }
    } // Заполняю двумерный массив массив случайнми числами от 0 до 99
    
    for(int i=0; i<10; i++){
    for(int j=0; j<10; j++){
    cout<<mas[i][j];
    if(mas[i][j]>=10) cout<<" ";
    else cout<<"  ";            
    }
    cout<<endl;    
    } // Вывожу на экран
    
    cout<<endl;
    
    int var_mas2[10*10], m = 0;
    
    for(int i=0; i<10; i++){
    for(int j=0; j<10; j++){
    var_mas2[m] = mas[i][j];
    m++;
    }
    } // Складываю двумерный массив в одномерный
    
    cout<<endl<<endl;
    
    int vp;
 
    for(int i=0; i<10*10; i++){
    for(int j=0; j<10*10; j++){
    if(var_mas2[j]<var_mas2[j+1]){
    vp = var_mas2[j];
    var_mas2[j] = var_mas2[j+1];
    var_mas2[j+1] = vp;
    }
    }
    } // сортирую полученный из двумерного одномерный массив
    
    m=0;
    
    for(int i=0; i<10; i++){
    for(int j=0; j<10; j++){
    mas[i][j] = var_mas2[m];
    cout<<mas[i][j];
    m++;
    if(mas[i][j]>=10) cout<<" ";
    else cout<<"  ";
    }
    cout<<endl;
    } // вывожу на экран
    
    
    system("PAUSE");
    return EXIT_SUCCESS;
}
В общем то код работает но вот почему то когда я пытаюсь вывести уже отсортированный массив первая цифра не выводится (выходит что то вроде 4063608) остальные 99 выводятся в правильной последовательности. Ей богу ума не приложу где я ошибся, если не трудно укажите в каком месте ошибочка, буду благодарен! Писал все это в Dev C++ там все работает в визуале не знаю пройдет такой код или нет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.11.2013, 21:33
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Сортировка двумерного массива (C++):

Сортировка двумерного массива - C++
Подскажите как отсортировать двумерный массив по возрастанию. Например дан такой массив двумерный: 9 7 4 1 2 3 5 5 5 Должен...

Сортировка двумерного массива - C++
Добрый день. Дано было такое задание . &quot;Даны два числа n и m. Создать матрицу размером и заполнить случайными числами в диапазоне ....

сортировка двумерного массива - C++
#include&lt;stdio.h&gt; #include&lt;stdlib.h&gt; #include&lt;math.h&gt; #include&lt;conio.h&gt; int i,j,n,k,co,cp; ...

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

сортировка двумерного массива - C++
Имеется двумерный массив вещ. чисел,которое заполняется автоматически,нужно отсортировать все элементы в порядке возростании.( и блок-схему...

Сортировка двумерного массива - C++
Дан двумерный массив, размерностью N на N. Надо взять отдельно каждую строку и каждый столбец, отсортировать по возрастанию и сравнить с...

4
Somebody
2791 / 1602 / 147
Регистрация: 03.12.2007
Сообщений: 4,200
Завершенные тесты: 1
20.11.2013, 22:24 #2
В 43-й строке при j == 10*10-1 выход за границу массива.
1
Azerrot
8 / 8 / 1
Регистрация: 31.12.2012
Сообщений: 47
21.11.2013, 05:43  [ТС] #3
Спасибо, я попробовал заменить код условия с

C++
1
2
3
4
5
    if(var_mas2[j]<var_mas2[j+1]){
    vp = var_mas2[j];
    var_mas2[j] = var_mas2[j+1];
    var_mas2[j+1] = vp;
    }
на

C++
1
2
3
4
5
    if(var_mas2[j-1]<var_mas2[j]){
    vp = var_mas2[j-1];
    var_mas2[j-1] = var_mas2[j];
    var_mas2[j] = vp;
    }
и все встало на свои места!
0
Somebody
2791 / 1602 / 147
Регистрация: 03.12.2007
Сообщений: 4,200
Завершенные тесты: 1
21.11.2013, 11:56 #4
Ненадолго. Теперь при j == 0.
0
Azerrot
8 / 8 / 1
Регистрация: 31.12.2012
Сообщений: 47
21.11.2013, 21:29  [ТС] #5
Неее, я цикл тоже подправил так что бы он начинал пробегать его с позиции 1 а не с 0

C++
1
2
3
4
5
6
7
8
9
for(int i=0; i<10*10; i++){
    for(int j=1; j<10*10; j++){
    if(var_mas2[j-1]<var_mas2[j]){
    vp = var_mas2[j-1];
    var_mas2[j-1] = var_mas2[j];
    var_mas2[j] = vp;
    }
    }
    }
0
21.11.2013, 21:29
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.11.2013, 21:29
Привет! Вот еще темы с ответами:

Сортировка двумерного массива - C++
Здравствуйте, вот у меня есть массив array. Какими стандартными методами можно отсортировать весь массив по ячейкам ? Или стандартными...

Сортировка двумерного массива - C++
Здравствуйте! Есть задача: отсортировать чётные строки массива А по возрастанию, а нечётные по убыванию. Написал следующий код: ...

Сортировка двумерного массива - C++
Есть задачка с 3-ох пунктов. Первый я сделал(создать многомерный целочисельный масив заданый пользователем). А вот с двумя никак не могу...

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


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.