七大排序之冒泡排序

<BubbleSort>
基本思想:在[lo,hi]區(qū)間內(nèi)盼理,從左往右间涵,依次對相鄰元素進行比較,若逆序榜揖,交換兩元素位置(穩(wěn)定排序)勾哩,直至各元素有序抗蠢;



1.蠻力算法,不能及時提前退出思劳,總是必須做n-1趟掃描交換

void BubbleSort0(int a[],int lo,int hi)
{
    if(hi-lo<1) return;
    int n=hi-lo+1;
    while(n--)//在尚未確認全局有序前迅矛,逐趟進行掃描交換
    {
        for(int i=lo;i<lo+n-1;i++)
            if(a[i]>a[i+1])Swap(a[i],a[i+1]);

    }
}


  1. 借助布爾型標(biāo)志位sorted,可及時提前退出潜叛,而不致總是蠻力地做n - 1趟掃描交換;
    [若該趟未發(fā)生掃描交換秽褒,說明前序列已有序]
void BubbleSort1(int a[],int lo,int hi)
{
    if(hi-lo<1) return;
    int n=hi-lo+1;
    bool sorted=false; //整體排序標(biāo)志,首先假定尚未排序
    while(!sorted)
    {
        sorted=true;//假定已經(jīng)進行排序
        for(int i=lo+1;i<lo+n-1;i++)
            if(a[i-1]>a[i])
        {
            sorted=false;
            Swap(a[i-1],a[i]);
        }
        n--;
    }
}

完成的掃描交換趟數(shù)=實際發(fā)生元素交換的掃描交換趟數(shù)+1
但威兜,對尾部有序(或接近有序)的輸入销斟,算法依然亦步亦趨地收斂,導(dǎo)致元素比較次數(shù)過多



3.借助整數(shù)last盡快地收縮待排序區(qū)間:既可提前退出椒舵,更可減少每趟(及所有)掃描交換中元素比較操作
【若尾端元素已有序蚂踊,通過last將排序區(qū)間長度改變至無序區(qū)間的長度,若發(fā)生交換=無序=last前移笔宿,當(dāng)last=lo時排序完成】
對尾部有序(或接近有序)的輸入犁钟,算法收斂的速度大大提高
元素交換的次數(shù)僅取決于輸入序列,與前兩個版本相同

void BubbleSort2(int a[],int lo,int hi)
{
   if(hi-lo<1) return;
   int n=hi-lo+1;
   int last;
   for(;lo<n;n=last) //控制排序區(qū)間長度泼橘,n慢慢收縮至lo之前的位置涝动,每次last標(biāo)記的是
   {
       for(int i=lo;i<lo+n-1;i++)
       {
           if(a[i]>a[i+1])
           {
               Swap(a[i],a[i+1]);
               last=i;
           }
       }
   }
}

復(fù)雜度分析:
時間復(fù)雜度:
最好情況:(改進后的冒泡排序)本身有序,沒有數(shù)據(jù)交換炬灭,只有n次比較醋粟,復(fù)雜度為O(n);
最壞情況:排序表逆序重归,此時需比較1+2+3+...+(n-1)=n(n-1)/2次昔穴,同時需要作等數(shù)量級的記錄移動,因此總的時間復(fù)雜度為O(n^2)提前。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吗货,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子狈网,更是在濱河造成了極大的恐慌宙搬,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拓哺,死亡現(xiàn)場離奇詭異勇垛,居然都是意外死亡,警方通過查閱死者的電腦和手機士鸥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進店門闲孤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人烤礁,你說我怎么就攤上這事讼积》收眨” “怎么了?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵勤众,是天一觀的道長舆绎。 經(jīng)常有香客問我,道長们颜,這世上最難降的妖魔是什么吕朵? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮窥突,結(jié)果婚禮上努溃,老公的妹妹穿的比我還像新娘。我一直安慰自己阻问,他們只是感情好梧税,可當(dāng)我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著则拷,像睡著了一般。 火紅的嫁衣襯著肌膚如雪曹鸠。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天,我揣著相機與錄音麦锯,去河邊找鬼澎媒。 笑死,一個胖子當(dāng)著我的面吹牛邻眷,可吹牛的內(nèi)容都是我干的眠屎。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼肆饶,長吁一口氣:“原來是場噩夢啊……” “哼改衩!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起驯镊,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤葫督,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后板惑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體橄镜,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年冯乘,在試婚紗的時候發(fā)現(xiàn)自己被綠了洽胶。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡裆馒,死狀恐怖姊氓,靈堂內(nèi)的尸體忽然破棺而出丐怯,到底是詐尸還是另有隱情,我是刑警寧澤他膳,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布响逢,位于F島的核電站,受9級特大地震影響棕孙,放射性物質(zhì)發(fā)生泄漏舔亭。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一蟀俊、第九天 我趴在偏房一處隱蔽的房頂上張望钦铺。 院中可真熱鬧,春花似錦肢预、人聲如沸矛洞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽沼本。三九已至,卻和暖如春锭沟,著一層夾襖步出監(jiān)牢的瞬間抽兆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工族淮, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留辫红,地道東北人。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓祝辣,卻偏偏與公主長得像贴妻,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蝙斜,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 作者:nnngu GitHub:https://github.com/nnngu 博客園:http://www...
    nnngu閱讀 3,778評論 4 30
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 將一個記錄插入到已排序好...
    依依玖玥閱讀 1,254評論 0 2
  • 概述:排序有內(nèi)部排序和外部排序名惩,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進行排序,而外部排序是因排序的數(shù)據(jù)很大孕荠,一次不能容納全部...
    每天刷兩次牙閱讀 3,732評論 0 15
  • 參考這篇文章和我的理解绢片,objc_msgSend方法中,查找一個消息對應(yīng)的實現(xiàn)的過程大致應(yīng)該是這樣的: 檢測這個s...
    賣萌涼閱讀 366評論 0 2
  • 龜婆的錢錢 懸空七座島嶼的云層里岛琼,折射了獨流鎮(zhèn)地球村的海市蜃樓底循。 杜小胖的眼睛紅了。 她是個與人為善的好姑娘槐瑞,獨流...
    一指天空閱讀 231評論 0 1