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

Не могу понять код пузырьковой сортировки

14.07.2016, 16:51. Показов 1489. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Сам алгоритм работы ясен, а как это воплотить в код не могу понять. Если читать готовые коды, тоже не могу разобраться.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
14.07.2016, 16:51
Ответы с готовыми решениями:

Код пузырьковой сортировки массива по убыванию
Исходный массив -2.4 10.5 49.9 -49.9 -25.3 35.8 Написать код пузырьковой сортировки данного...

Составить программы для пузырьковой сортировки и сортировки посредством выбора с применением оператора while
Доброго времени суток, очень нужна ваша помощь в решении данной проблемы, буду бесконечно...

Методы сортировки!не могу понять почему не робит!
Всем привет,написал прогу и не работает,не могу понять почему!сколько раз просматривал все норм...

Алгоритм пузырьковой сортировки
#include<iostream.h> #define SIZE 5 void bsort (int iArray, int n); int main() { char ch;...

6
2664 / 2239 / 240
Регистрация: 03.07.2012
Сообщений: 8,141
Записей в блоге: 1
14.07.2016, 17:58 2
Если ясен, напиши словами, по-русски.
0
👻👻👻
21 / 28 / 12
Регистрация: 22.04.2016
Сообщений: 166
14.07.2016, 18:18 3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
void bubble_sort(int *a, int length)
{
     for (int i = 0; i < length-1; i++) { 
        bool swapped = false;
         for (int j = 0; j < length-i-1; j++) {
             if (a[j] > a[j+1]) {
                 int b = a[j]; 
                 a[j] = a[j+1];
                 a[j+1] = b;
                 swapped = true;
             }
         }
         
         if(!swapped)
            break;
     }
 }
В первом цикле проходим до length-1 элемента, потому что сравниваем 1 элемент со вторым, второй с третьим, length-1 с length-ым. А если будем проходить до length-ного элемента, то будет сравниваться 1 со 2, 2 с 3-им, length с length + 1-ым, но length+1-ого элемента нет
Во вложенном проходим до length-i-1-ого, так как старший элемент уже в самом конце, и с ним сравнивать не надо.
Чтобы лучше понять, изобразите сортировку на бумаге.
1
Эксперт CЭксперт С++
5113 / 4552 / 854
Регистрация: 07.10.2015
Сообщений: 9,462
14.07.2016, 18:26 4
Я делаю немного по-другому
Самые меньшие из оставшихся "всплывают" к началу массива
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
void bubble_sort(int *a, int length)
{
     for (int i = 0; i < length-1; i++) //текущий - от первого до предпоследнего
     { 
         for (int j = i+1; j < length; j++) //от следующего за текущим до конца
         {
             if (a[i] > a[j]) //если текущий больше какого-то из следующих
             {
                 int b = a[i]; //то меняем местами
                 a[i] = a[j];  //тем самым на месте текущего окажется самый меньший
                 a[j] = b;
             }
         }
     }
 }
0
Неэпический
17870 / 10635 / 2054
Регистрация: 27.09.2012
Сообщений: 26,737
Записей в блоге: 1
14.07.2016, 19:51 5
Алгоритмы сортировок
0
Эксперт С++
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
15.07.2016, 08:56 6
Цитата Сообщение от _liv_ Посмотреть сообщение
//то меняем местами
В переводе на человеческий это std::swap, и комментариев никаких не надо.
0
2664 / 2239 / 240
Регистрация: 03.07.2012
Сообщений: 8,141
Записей в блоге: 1
15.07.2016, 09:18 7
У ТС, похоже, проблемы с человеческим. Он не написал, как он понимает сам алгоритм, не написал конкретные места в коде, которые он не понял, поэтому ему можно только посочувствовать.

Не по теме:

Получается, как у собак: "все понимают, только сказать не могут".

0
15.07.2016, 09:18
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
15.07.2016, 09:18
Помогаю со студенческими работами здесь

Анализ пузырьковой сортировки
здравствуйте. дайте пжл доступные статьи по теме : анализ среднего случая пузырьковой сортировки

Метод пузырьковой сортировки
Подскажите как сделать сортировку одномерного массива методом пузырька по убыванию? //сортировка...

Шаблон пузырьковой сортировки
У меня проблемы с шаблоном пузырьковой сортировки. Почему элементы double не сортируется...

Процедура пузырьковой сортировки
Мне нужна эта процедура на Си++. Как представить запись на Си++? type tKey = string; ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru