欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Objective-C實現(xiàn)冒泡排序算法的簡單示例

 更新時間:2016年06月21日 09:55:09   作者:manji  
冒泡排序即是依次比較相鄰的兩個數(shù),如果后面的數(shù)較小則交換到前面一個數(shù)的位置上,這里我們來看一下Objective-C實現(xiàn)冒泡排序算法的簡單示例

簡介
冒泡算法是一種基礎的排序算法,這種算法會重復的比較數(shù)組中相鄰的兩個元素。如果一個元素比另一個元素大(?。?,那么就交換這兩個元素的位置。重復這一比較直至最后一個元素。這一比較會重復n-1趟,每一趟比較n-j次,j是已經(jīng)排序好的元素個數(shù)。每一趟比較都能找出未排序元素中最大或者最小的那個數(shù)字。這就如同水泡從水底逐個飄到水面一樣。冒泡排序是一種時間復雜度較高,效率較低的排序方法。其空間復雜度是O(n)。
1, 最差時間復雜度 O(n^2)
2, 平均時間復雜度 O(n^2)

實現(xiàn)思路
1,每一趟比較都比較數(shù)組中兩個相鄰元素的大小
2,如果i元素小于i-1元素,就調(diào)換兩個元素的位置
3,重復n-1趟的比較

Objective-C示例:

+(void)bubbleSort:(NSMutableArray *)list{
 if (list.count <= 1) {
  return;
 }
 int i, y;
 BOOL bFinish = YES; //是否發(fā)生數(shù)據(jù)交換
 for (i = 1; i<= [list count] && bFinish; i++) {
  bFinish = NO; //每次遍歷時,重置標志
  //從最后一位開始,依次跟前一位相比,如果較小,則交換位置
  //當一次遍歷沒有任何數(shù)據(jù)交換時,則說明已經(jīng)排序完成(bFinish=YES),則不再進行循環(huán)
  for (y = (int)[list count]-1; y>=i; y--) {
   if ([[list objectAtIndex:y] intValue] < [[list objectAtIndex:y-1] intValue]) {
    //交換位置
//    NSLog(@"%d<->%d",[[array objectAtIndex:y-1] intValue],[[array objectAtIndex:y] intValue]);
    [list exchangeObjectAtIndex:y-1 withObjectAtIndex:y];
    bFinish = YES; //發(fā)生數(shù)據(jù)交換,則繼續(xù)進行下一次遍歷,直到未發(fā)生數(shù)據(jù)交換或者循環(huán)完成為止

//    NSLog(@"%@",[array componentsJoinedByString:@" "]);
   }
   
  }
 }
}

相關(guān)文章

  • IOS 禁止縮放頁面的實現(xiàn)方法

    IOS 禁止縮放頁面的實現(xiàn)方法

    這篇文章主要介紹了IOS 禁止縮放頁面的實現(xiàn)方法的相關(guān)資料,這里主要介紹了IOS 10如何通過設置來實現(xiàn)禁止縮放及實現(xiàn)方法,需要的朋友可以參考下
    2017-07-07
  • iOS開發(fā)避免安全隱患的要點總結(jié)

    iOS開發(fā)避免安全隱患的要點總結(jié)

    在本篇文章里小編給各位整理了關(guān)于iOS開發(fā)如何避免安全隱患的知識點總結(jié),需要的朋友們學習下。
    2019-07-07
  • iOS webview捕獲H5按鈕方法示例代碼

    iOS webview捕獲H5按鈕方法示例代碼

    這篇文章主要給大家介紹了關(guān)于iOS webview捕獲H5按鈕方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-01-01
  • iOS實現(xiàn)從通訊錄中選擇聯(lián)系人

    iOS實現(xiàn)從通訊錄中選擇聯(lián)系人

    這篇文章主要為大家詳細介紹了iOS實現(xiàn)從通訊錄中選擇聯(lián)系人,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • IOS開發(fā)-多線程隊列測試代碼

    IOS開發(fā)-多線程隊列測試代碼

    這篇文章中,我不會說多線程是什么、線程和進程的區(qū)別、多線程有什么用,當然我也不會說什么是串行、什么是并行等問題,這些我們應該都知道的。
    2017-09-09
  • iOS獲取本地音頻文件(屬性/信息)

    iOS獲取本地音頻文件(屬性/信息)

    這篇文章主要為大家詳細介紹了iOS獲取本地音頻文件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • IOS檢測指定路徑的文件是否存在

    IOS檢測指定路徑的文件是否存在

    本文給大家分享的是在IOS開發(fā)中檢測指定文件是否存在的方法,給大家匯總了4種,十分實用,小伙伴們根據(jù)自己的需求自由選擇吧。
    2015-05-05
  • iOS實現(xiàn)手機獲取驗證碼倒計時效果

    iOS實現(xiàn)手機獲取驗證碼倒計時效果

    這篇文章主要為大家詳細介紹了iOS實現(xiàn)手機獲取驗證碼倒計時效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Swift 進階 —— map 和 flatMap的使用

    Swift 進階 —— map 和 flatMap的使用

    這篇文章主要介紹了Swift map和flatMap的相關(guān)資料,幫助大家更好的理解和使用Swift,感興趣的朋友可以了解下
    2020-09-09
  • IOS 長鏈接與短鏈接之間的轉(zhuǎn)換

    IOS 長鏈接與短鏈接之間的轉(zhuǎn)換

    這篇文章主要介紹了IOS 長鏈接與短鏈接之間的轉(zhuǎn)換的相關(guān)資料,需要的朋友可以參考下
    2017-06-06

最新評論