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

Обратный метод пузырька

20.10.2011, 21:03. Показов 14392. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать программу сортировки массива по возрастанию методом "погружения " наибольшего ("тяжелого") элемента(метод пузырька в обратную сторону ). Непонятно как это сделать..
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.10.2011, 21:03
Ответы с готовыми решениями:

Поменять метод пузырька на метод вставки
int main() { SetConsoleCP(1251); SetConsoleOutputCP(1251); srand(time(NULL)); int arr, tmp; int temp, n = 0; for (int i...

Метод пузырька и метод слияния
Сгенерировать одномерный массив из N случайных чисел xi ∈. Отсортировать массив методом пузырька и методом слияния. Подсчитать число...

Метод пузырька
реализовать на языке С++ сортировку одномерного массива методом «пузырька», методом вставки, методом выбора.

7
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
20.10.2011, 21:50
C++
1
2
3
4
5
6
    for(int i=0; i<n-1; i++)
        for(int j=0; j<n-i-1; j++)
            if(mas[j]>mas[j+1])
            {
                int tmp=mas[j]; mas[j]=mas[j+1]; mas[j+1]=tmp;
            }
1
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
20.10.2011, 22:04
Цитата Сообщение от Stas12 Посмотреть сообщение
методом "погружения " наибольшего ("тяжелого") элемента(метод пузырька в обратную сторону )
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void BubbleSort(int *a, const int n)
{
   int i, left = 0, flag, buf;
   do
   {
      flag = 0;
      for(i = n - 1; i > left; i--)
         if (a[i-1] > a[i])
         {
            buf = a[i]; a[i] = a[i-1]; a[i-1] = buf;
            flag = 1;
         }
      left++;
   }
   while(flag);
}
Хотя, задание бы уточнить, у меня в такой терминологии происходит всплытие "легких" элементов, но ведь это и есть обратная сортировка пузырьковому методу, разве нет?
В любом случае желательнее использовать логическую переменную, чтобы избежать лишних шагов)
0
0 / 0 / 1
Регистрация: 20.10.2011
Сообщений: 102
20.10.2011, 22:12  [ТС]
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <stdio.h>
#include <math.h>
#include <conio.h>
#include <locale.h>
void main ()
 
{   
    setlocale(LC_ALL, "Russian");
    int n,tmp;
    int mas[50];
    printf("Введите элементы массива : \n");
    scanf("%d",&n);
    for(int i=0; i<n-1; i++)
                for(int j=0; j<n-i-1; j++)
                        if(mas[j]>mas[j+1])
                        {
                                int tmp=mas[j]; mas[j]=mas[j+1]; mas[j+1]=tmp;
                        }
                        getch ();
}
вот дописал, но что то не работает(((

Добавлено через 3 минуты
мне нужно чтобы сортировка была обратной, то есть мы не меньшие элементы поднимаем вверх, а наоборот наибольшие элементы опускаем вниз..

 Комментарий модератора 
Используйте теги форматирования кода!
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
20.10.2011, 22:14
Цитата Сообщение от Stas12 Посмотреть сообщение
мне нужно чтобы сортировка была обратной, то есть мы не меньшие элементы поднимаем вверх, а наоборот наибольшие элементы опускаем вниз..
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
#include<stdio.h>
void BubbleSort(int *a, const int n)
{
   int i, right = n, flag;
   int buf;
   do
   {
      flag = 0;
      for(i = 1; i < right; i++)
         if (a[i-1] > a[i])
         {
            buf = a[i]; a[i] = a[i-1]; a[i-1] = buf;
            flag = 1;
         }
      right--;
   }
   while(flag);
}
 
int main()
{
   int i, a[5] = {50, 40, 30, 20, 10};
   BubbleSort(a, 5);
   for(i = 0; i < 5; i++)
      printf("%d ", a[i]);
   getchar();
}
0
0 / 0 / 1
Регистрация: 20.10.2011
Сообщений: 102
20.10.2011, 22:16  [ТС]
Цитата Сообщение от Thinker Посмотреть сообщение
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
#include<stdio.h>
void BubbleSort(int *a, const int n)
{
   int i, right = n, flag;
   int buf;
   do
   {
      flag = 0;
      for(i = 1; i < right; i++)
         if (a[i-1] > a[i])
         {
            buf = a[i]; a[i] = a[i-1]; a[i-1] = buf;
            flag = 1;
         }
      right--;
   }
   while(flag);
}
 
int main()
{
   int i, a[5] = {50, 40, 30, 20, 10};
   BubbleSort(a, 5);
   for(i = 0; i < 5; i++)
      printf("%d ", a[i]);
   getchar();
}
спасибо огромное, а можно чуть чуть комментариев к коду?))))
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
20.10.2011, 22:21
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
#include<stdio.h>
void BubbleSort(int *a, const int n)
{
   int i,
       right = n, // правая граница
       flag;    // отвечает за то, упорядочен ли массив
   int buf;   // буфер 
   do
   {
      flag = 0;
      for(i = 1; i < right; i++)
         if (a[i-1] > a[i])    // проверяем на наличие инверсии
         {
            buf = a[i]; a[i] = a[i-1]; a[i-1] = buf;  // меняем местами a[i-1] и a[i]
            flag = 1;  // нашли инверсию
         }
      right--;   // максимальные элементы прибиваются вправо
   }
   while(flag);
}
 
int main()
{
   int i, a[5] = {50, 40, 30, 20, 10};
   BubbleSort(a, 5);
   for(i = 0; i < 5; i++)
      printf("%d ", a[i]);
   getchar();
}
0
0 / 0 / 1
Регистрация: 20.10.2011
Сообщений: 102
20.10.2011, 22:22  [ТС]
Цитата Сообщение от Thinker Посмотреть сообщение
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
#include<stdio.h>
void BubbleSort(int *a, const int n)
{
   int i,
       right = n, // правая граница
       flag;    // отвечает за то, упорядочен ли массив
   int buf;   // буфер 
   do
   {
      flag = 0;
      for(i = 1; i < right; i++)
         if (a[i-1] > a[i])    // проверяем на наличие инверсии
         {
            buf = a[i]; a[i] = a[i-1]; a[i-1] = buf;  // меняем местами a[i-1] и a[i]
            flag = 1;  // нашли инверсию
         }
      right--;   // максимальные элементы прибиваются вправо
   }
   while(flag);
}
 
int main()
{
   int i, a[5] = {50, 40, 30, 20, 10};
   BubbleSort(a, 5);
   for(i = 0; i < 5; i++)
      printf("%d ", a[i]);
   getchar();
}
спасибо, выручил , очень))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.10.2011, 22:22
Помогаю со студенческими работами здесь

метод пузырька
не работает, выдает ошибку при запуске. Undefined symbol _main in module c0.ASM подскажите пожалуйста как исправить? #include...

Метод пузырька
Здравствуйте. Как сделать сортировку по методу пузырька с максимального значения и далее? Т.е. 6 3 9 7 2 4 5 6 -&gt; 6 3 9 2 4 5 6 7. ...

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

Метод пузырька
Дано n (n&lt;=32000) натуральных чисел xi, (xi&lt;m). Необходимо установить, можно ли разбить их на пары таким образом, чтобы сумма чисел в...

Метод пузырька
Ввести размерность и элементы массива с клавиатуры 2. Отсортировать массив указанным способом 3. Вывести отсортированный массив в...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru