Lila25mila
Lila25mila25. Februar 2019 03:29

Bubble-Sort-Algorithmus

Der Bubble-Sort-Algorithmus beginnt damit, die ersten beiden Elemente eines Arrays zu vergleichen und gegebenenfalls zu ersetzen. Wenn Sie beispielsweise die Elemente eines Arrays in aufsteigender Reihenfolge sortieren möchten und das erste Element größer als das zweite ist, müssen Sie die Elemente vertauschen. Wenn das erste Element kleiner als das zweite ist, dürfen Sie es nicht vertauschen. Das zweite und das dritte Element werden dann erneut verglichen und gegebenenfalls ausgetauscht, und dieser Prozess wird fortgesetzt, bis das letzte und das vorletzte Element verglichen und ausgetauscht wurden. Damit ist der erste Schritt der Blasensortierung abgeschlossen.


Wenn n Elemente zu sortieren sind, sollte der oben erwähnte Vorgang n-1 Mal wiederholt werden, um das gewünschte Ergebnis zu erhalten. Aber für eine bessere Performance im zweiten Schritt werden das letzte und das vorletzte Element nicht verglichen, da das entsprechende Element automatisch nach dem ersten Schritt ans Ende gesetzt wird. Ebenso werden im dritten Schritt die letzten und vorletzten und vorletzten Elemente nicht verglichen und so weiter.

Schauen wir uns zum besseren Verständnis die Abbildung an.

Die Abbildung zeigt 5 Elemente zum Sortieren und 4 Schritte.

Programm zum Sortieren von Elementen mit Bubble-Sort-Algorithmus
// Программа для сортировки данных в порядке возрастания с использованием пузырьковой сортировки. 
#include <stdio.h>
int main()
{
    int data[100],i,n,step,temp;
    printf("Enter the number of elements to be sorted: ");
    scanf("%d",&n);
    for(i=0;i<n;++i)
    {
        printf("%d. Enter element: ",i+1);
        scanf("%d",&data[i]);
    }

    for(step=0;step<n-1;++step)
    for(i=0;i<n-step-1;++i)
    {
        if(data[i]>data[i+1])   // Чтобы отсортировать в порядке убывания, измените > на < в этой строке. 
        {
            temp=data[i];
            data[i]=data[i+1];
            data[i+1]=temp;
        }
    }
    printf("In ascending order: ");
    for(i=0;i<n;++i)
         printf("%d  ",data[i]);
    return 0;
}
Enter number of terms(should be less than 100): 5
Enter elements: 12
1
2
5
3
In ascending order: 1     2     3     5     12

Hinweis: Obwohl dieser Code in der C-Programmierung verwendet wird, kann diese Methode in jeder Programmierung verwendet werden, um die Elemente eines Arrays zu sortieren.
Der Bubble-Sort-Algorithmus ist sehr beliebt, aber es gibt viele bessere Algorithmen als Bubble-Sort.

Aufmerksamkeit! Blasensortierung sollte nicht zum Sortieren großer Datenmengen verwendet werden, wenn die Leistung dieses Programms ein Problem darstellt.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken