swift 3.1 堆排序

//
func heapsAdjust(array:Array<Int>, parent:Int, length:Int) -> Array<Int> {

    var array = array
    var parent = parent
    
    let parentPoint = array[parent] //父節(jié)點
    var child = parent*2+1 //左節(jié)點
    
    while child+1<=length {
        if child+1<length && array[child]<array[child+1] {
            child = child + 1
        }
        if parentPoint < array[child] {
            array[parent] = array[child]
            
            parent = child
            child = child*2+1
        }else {
            break;
        }
    }
    array[parent] = parentPoint
    
    return array
}
//排序
func heapSort(array:Array<Int>) -> Array<Any>? {
    var array = array

   // 循環(huán)建立初始堆
    for  i in (0...array.count/2).reversed() {
        autoreleasepool {
            array = heapsAdjust(array: array, parent: i, length: array.count)
        }
    }
    
    for  i in (0...array.count-1).reversed() {
        autoreleasepool {
            
            // 最后一個元素和第一元素進行交換
            let temp = array[i];
            array[i] = array[0];
            array[0] = temp;
            
            array = heapsAdjust(array: array, parent: 0, length: i)
            print("\(array.count-i)---\(array)")
        }
    }
    
    return array
}

調(diào)用:

  heapSort(array: [1, 3, 4, 5, 2, 6, 9, 7, 8, 0])
reason.png

參考:
http://www.cnblogs.com/jingmoxukong/p/4303826.html

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末图呢,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子疮薇,更是在濱河造成了極大的恐慌笤昨,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件停士,死亡現(xiàn)場離奇詭異挖帘,居然都是意外死亡,警方通過查閱死者的電腦和手機恋技,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門拇舀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蜻底,你說我怎么就攤上這事骄崩。” “怎么了薄辅?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵要拂,是天一觀的道長。 經(jīng)常有香客問我站楚,道長脱惰,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任窿春,我火速辦了婚禮拉一,結果婚禮上,老公的妹妹穿的比我還像新娘旧乞。我一直安慰自己蔚润,他們只是感情好,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布尺栖。 她就那樣靜靜地躺著嫡纠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪延赌。 梳的紋絲不亂的頭發(fā)上除盏,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天,我揣著相機與錄音皮胡,去河邊找鬼痴颊。 笑死,一個胖子當著我的面吹牛屡贺,可吹牛的內(nèi)容都是我干的蠢棱。 我是一名探鬼主播锌杀,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼泻仙!你這毒婦竟也來了糕再?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤玉转,失蹤者是張志新(化名)和其女友劉穎突想,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體究抓,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡猾担,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了刺下。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绑嘹。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖橘茉,靈堂內(nèi)的尸體忽然破棺而出工腋,到底是詐尸還是另有隱情,我是刑警寧澤畅卓,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布擅腰,位于F島的核電站,受9級特大地震影響翁潘,放射性物質(zhì)發(fā)生泄漏趁冈。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一唐础、第九天 我趴在偏房一處隱蔽的房頂上張望箱歧。 院中可真熱鬧矾飞,春花似錦一膨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至申眼,卻和暖如春瞒津,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背括尸。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工巷蚪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人濒翻。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓屁柏,卻偏偏與公主長得像啦膜,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子淌喻,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

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

  • 背景 一年多以前我在知乎上答了有關LeetCode的問題, 分享了一些自己做題目的經(jīng)驗僧家。 張土汪:刷leetcod...
    土汪閱讀 12,743評論 0 33
  • *面試心聲:其實這些題本人都沒怎么背,但是在上海 兩周半 面了大約10家 收到差不多3個offer,總結起來就是把...
    Dove_iOS閱讀 27,139評論 30 470
  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile麗語閱讀 3,831評論 0 6
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)裸删,斷路器八拱,智...
    卡卡羅2017閱讀 134,652評論 18 139
  • 喜歡一個人匕荸,就像喜歡富士山灯萍,你可以看到它,但是不能搬走它每聪,這是我第一次看到愛情無疾而終的樣子后體會到的旦棉。 你有什么...
    丑兒姑娘閱讀 727評論 1 2