C++冒泡排序算法實(shí)例
冒泡排序
大學(xué)學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)與算法最開始的時(shí)候,就講了冒泡排序;可見這個(gè)排序算法是多么的經(jīng)典。冒泡排序是一種非常簡(jiǎn)單的排序算法,它重復(fù)地走訪過要排序的數(shù)列,每一次比較兩個(gè)數(shù),按照升序或降序的規(guī)則,對(duì)比較的兩個(gè)數(shù)進(jìn)行交換。比如現(xiàn)在我要對(duì)以下數(shù)據(jù)進(jìn)行排序:
10 3 8 0 6 9 2
當(dāng)使用冒泡排序進(jìn)行升序排序時(shí),排序的步驟是這樣的:
3 10 8 0 6 9 2 // 10和3進(jìn)行對(duì)比,10>3,交換位置
3 8 10 0 6 9 2 // 10再和8進(jìn)行對(duì)比,10>8,交換位置
3 8 0 10 6 9 2 // 10再和0進(jìn)行對(duì)比,10>0,交換位置
……
3 8 0 6 9 2 10 // 這個(gè)時(shí)候,10到達(dá)了最右邊,是最大的數(shù)字,此時(shí),我們?cè)趶念^開始進(jìn)行對(duì)比
3 8 0 6 9 2 10 // 3小于8,所以不用交換位置
3 0 8 6 9 2 10 // 8大于0,所以交換位置
……
0 2 3 6 8 9 10
很簡(jiǎn)單,就是讓大數(shù)沉入下面,小數(shù)慢慢上浮起來。冒泡排序的時(shí)間復(fù)雜度也為O(n^2)。
代碼實(shí)現(xiàn)
#include <iostream>
using namespace std;
void BubbleSort(int arr[], int length)
{
int temp;
for (int i = 0; i < length; ++i)
{
for (int j = 0; j < length - i - 1; ++j)
{
if (arr[j] > arr[j + 1])
{
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main()
{
int arr[10] = {2, 4, 1, 0, 8, 4, 8, 9, 20, 7};
BubbleSort(arr, sizeof(arr) / sizeof(arr[0]));
for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); ++i)
{
cout<<arr[i]<<" ";
}
cout<<endl;
return 0;
}
相關(guān)文章
簡(jiǎn)單談?wù)勱P(guān)于C++中大隨機(jī)數(shù)的問題
這篇文章主要介紹了關(guān)于C++中大隨機(jī)數(shù)的問題,文中給出了詳細(xì)的示例代碼,相信對(duì)大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,有需要的朋友可以一起來學(xué)習(xí)學(xué)習(xí)。2017-01-01C++20中的協(xié)程(Coroutine)的實(shí)現(xiàn)
這篇文章主要介紹了C++20中的協(xié)程(Coroutine)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03C語言 深入解讀數(shù)據(jù)結(jié)構(gòu)之堆的實(shí)現(xiàn)
堆就是用數(shù)組實(shí)現(xiàn)的二叉樹,所以它沒有使用父指針或者子指針。堆根據(jù)“堆屬性”來排序,“堆屬性”決定了樹中節(jié)點(diǎn)的位置2021-11-11深入解析C++編程中__alignof 與__uuidof運(yùn)算符的使用
這篇文章主要介紹了C++編程中__alignof 與__uuidof運(yùn)算符的使用,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2016-01-01C語言實(shí)現(xiàn)實(shí)驗(yàn)設(shè)備管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)實(shí)驗(yàn)設(shè)備管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06Visual Studio 2019配置OpenCV4.1.1詳細(xì)圖解教程
這篇文章主要介紹了Visual Studio 2019配置OpenCV4.1.1詳細(xì)圖解教程 ,需要的朋友可以參考下2020-02-02關(guān)于嘗試開發(fā)PHP的MYSQL擴(kuò)展的使用
本篇文章小編將為大家介紹,關(guān)于嘗試開發(fā)PHP的MYSQL擴(kuò)展的使用,需要的朋友可以參考一下2013-04-04C++ OpenCV實(shí)戰(zhàn)之手勢(shì)識(shí)別
這篇文章主要介紹了如何利用C++?OpenCV實(shí)現(xiàn)手勢(shì)識(shí)別,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)OpenCV有一定幫助,感興趣的小伙伴可以了解一下2022-04-04windows?使用ffmpeg?.a靜態(tài)庫讀取Wav音頻并保存PCM的方法
這篇文章主要介紹了windows?使用ffmpeg?.a靜態(tài)庫讀取Wav音頻并保存PCM,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-02-02