網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
起泡排序的基本思想
起泡排序易于冒泡排序算法合并,即向后推出最大數(shù)。將被排序的記錄數(shù)組R[1..n]垂直排列,每個(gè)記錄R[i]看作是重量為R[i]的氣泡。根據(jù)輕氣泡不能在重氣泡之下的原則,從下往上掃描數(shù)組R:凡掃描到違反本原則的輕氣泡,就使其向上“飄浮”。如此反復(fù)進(jìn)行,直到最后任何兩個(gè)氣泡都是輕者在上,重者在下為止。一般地,第i遍處理時(shí),不必檢查第i個(gè)位置以上的元素,因?yàn)榻?jīng)過(guò)前面i-1遍的處理,它們已正確地排好序。即就是在一組待排序的數(shù)據(jù)中,兩兩比較數(shù)據(jù)的大小,發(fā)現(xiàn)兩個(gè)記錄的排序次序相反時(shí)就交換位置,直到?jīng)]有反序的記錄為止。也就是說(shuō)它重復(fù)地走訪過(guò)要排序的序列,一次比較兩個(gè)項(xiàng)目,如果他們的順序錯(cuò)誤就把他們交換過(guò)來(lái)。走訪序列的工作是重復(fù)地進(jìn)行直到?jīng)]有再需要做交換動(dòng)作,該序列已經(jīng)排序完成。一趟冒泡,至少可以把值最大的元素送到最后位置(或最上邊);當(dāng)然也可以倒過(guò)來(lái)做,把值小的元素向前移或向下移,一趟冒泡,至少可以把值最小的元素送到最前面的位置(或最下邊)。
雙向起泡排序?qū)崿F(xiàn)如下
#include<iostream>
using namespace std;
// 交換兩個(gè)數(shù)
void swap(int &i, int &j)
{
int t = i;
i = j;
j = t;
}
// 打印數(shù)組
void show(int a[], int n)
{
for(int i = 0; i < n; i++)
{
cout << a[i] << " ";
}
cout << endl;
}
// 雙向起泡排序
void bubblesort(int a[], int n)
{
int low = 0, high = n-1;
bool flag = true;
while(low < high && flag)
{
flag = false;
show(a, 10);
int i = low;
while(i < high)
{
if(a[i] > a[i + 1])
{
swap(a[i], a[i + 1]);
flag = true;
}
i++;
}
high--;
int j = high;
while(j > low)
{
if(a[j] < a[j-1])
{
swap(a[j-1], a[j]);
flag = true;
}
j--;
}
low++;
}
}
int main(){
int a[] = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
int n = 10;
// 輸出初始狀態(tài)
// show(a, n);
// 雙向冒泡排序
bubblesort(a, n);
// 排序后輸出
cout << "after sort" << endl;
show(a, n);
}
代碼中示例的輸出為:
10 9 8 7 6 5 4 3 2 1?
1 9 8 7 6 5 4 3 2 10?
1 2 8 7 6 5 4 3 9 10
1 2 3 7 6 5 4 8 9 10
1 2 3 4 6 5 7 8 9 10
after sort
1 2 3 4 5 6 7 8 9 10
原文鏈接:https://blog.csdn.net/m0_48205050/article/details/127751222
相關(guān)推薦
- 2022-12-24 MobPush?for?Flutter集成準(zhǔn)備_IOS
- 2022-12-02 Android系統(tǒng)狀態(tài)欄定制圖標(biāo)顯示邏輯控制_Android
- 2022-11-17 React通過(guò)classnames庫(kù)添加類(lèi)的方法_React
- 2022-05-12 Kotlin zip函數(shù) 合并成鍵值對(duì)
- 2022-11-09 Android性能優(yōu)化之plt?hook與native線程監(jiān)控詳解_Android
- 2022-05-06 如何利用Go語(yǔ)言實(shí)現(xiàn)LRU?Cache_Golang
- 2021-11-03 Linux系統(tǒng)下grub.cfg文件損壞修復(fù)步驟_Linux
- 2022-04-12 原生drag拖拽后元素過(guò)大,擋住其他可拖動(dòng)位置無(wú)法拖動(dòng)問(wèn)題
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支