国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++冒泡排序算法實例

2020-01-26 15:15:58
字體:
來源:轉載
供稿:網友

冒泡排序

大學學習數據結構與算法最開始的時候,就講了冒泡排序;可見這個排序算法是多么的經典。冒泡排序是一種非常簡單的排序算法,它重復地走訪過要排序的數列,每一次比較兩個數,按照升序或降序的規則,對比較的兩個數進行交換。比如現在我要對以下數據進行排序:

10 3 8 0 6 9 2

當使用冒泡排序進行升序排序時,排序的步驟是這樣的:

3 10 8 0 6 9 2  // 10和3進行對比,10>3,交換位置

3 8 10 0 6 9 2  // 10再和8進行對比,10>8,交換位置

3 8 0 10 6 9 2  // 10再和0進行對比,10>0,交換位置

……

3 8 0 6 9 2 10  // 這個時候,10到達了最右邊,是最大的數字,此時,我們在從頭開始進行對比

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

很簡單,就是讓大數沉入下面,小數慢慢上浮起來。冒泡排序的時間復雜度也為O(n^2)。

代碼實現

復制代碼 代碼如下:

#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;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 车致| 和平县| 南华县| 龙泉市| 怀集县| 文成县| 庆云县| 平泉县| 奉化市| 东乡族自治县| 宜兰市| 鄂尔多斯市| 栾城县| 房产| 加查县| 怀柔区| 海阳市| 永州市| 盘山县| 乌拉特前旗| 武邑县| 离岛区| 西乡县| 沙河市| 宁津县| 黄陵县| 吉隆县| 五华县| 嘉荫县| 宜昌市| 灵宝市| 余干县| 乐亭县| 济阳县| 噶尔县| 余江县| 平昌县| 开远市| 永昌县| 台江县| 澳门|