算法

冒泡排序纸肉、選擇排序
  • swift 寫法

import Foundation
/**
 *  冒泡排序:
 *      它重復(fù)地走訪過要排序的元素列践付,一次比較兩個(gè)相鄰的元素,如果他們的順序(如從大到小、首字母從A到Z)錯(cuò)誤就把他們交換過來号胚。走訪元素的工作是重復(fù)地進(jìn)行直到?jīng)]有相鄰元素需要交換愉适,也就是說該元素已經(jīng)排序完成。
 *
 *  選擇排序(Selection sort):
        1)它是一種簡單直觀的排序算法栗竖。
        2)它的工作原理是每一次從待排序的數(shù)據(jù)元素中選出最惺畲唷(或最大)的一個(gè)元素,存放在序列的起始位置狐肢,直到全部待排序的數(shù)據(jù)元素排完添吗。
        3)選擇排序是不穩(wěn)定的排序方法。
 *
 *
 */

/// 排序法:冒泡排序份名、選擇排序
struct AortMethod {
    
    
    /// 冒泡排序
    ///
    /// - Parameter array: 數(shù)組
    /// - Returns: [Int]
    func bubbleSort(array:[Int]) -> [Int] {
        print("冒泡排序原始數(shù)據(jù):\(array)")
        
        if array.count == 0 {
            return [Int]()
        }
        
        var arr = array
        var times = 0
        for i in 0 ..< arr.count - 1 {
            
            for j in 0 ..< arr.count - (i + 1) {
                times += 1
                if arr[j] > arr[j + 1] {    //交換位置
                    
                    //arr.swapAt(i, j + 1)    //系統(tǒng)的方法:交換位置
                    
                    let temp  = arr[j]
                    arr[j] = arr[j + 1]
                    arr[j + 1] = temp
                }
            }
        }
        
        print("冒泡排序后數(shù)據(jù):\(arr) , 循環(huán)次數(shù):\(times)")

        return arr
    }
    
    /// 選擇排序
    ///
    /// - Parameter array: 數(shù)組
    /// - Returns: [Int]
    func selectionSort(array:[Int]) -> [Int] {
        print("選擇排序原始數(shù)據(jù):\(array)")
        
        if array.count == 0 {
            return [Int]()
        }
        
        var times = 0
        var arr = array
        for i in 0 ..< arr.count - 1 {
           
            for j in i + 1 ..< arr.count {
                times += 1
               
                if arr[i] > arr[j] {
                    let temp  = arr[i]
                    arr[i] = arr[j]
                    arr[j] = temp
                }
            }
        }
        print("選擇排序后數(shù)據(jù):\(arr) , 循環(huán)次數(shù):\(times)")

        return arr
    }
        
    func swapDemo(a:inout Int, b: inout Int) {
        let temp  = a
        a = b
        b = temp
    }
}


  • OC 寫法
    //冒泡
    NSMutableArray *array = [NSMutableArray arrayWithArray:@[@"98",@"75",@"89",@"53",@"67",@"92"]];
    for (int i = 0 ; i < array.count-1; i ++) {
        for (int j = 0 ; j < array.count - 1 - i ; j ++) {
            if ([array[j] intValue] > [array[j+1] intValue]) {
                // 開始交換數(shù)據(jù)
                NSString *temp = array[j];

                array[j] = array[j+1];

                array[j+1] = temp;

            }
        }

    }
    
    //選擇
    for (int i = 0; i < array.count - 1;  i ++) {
       
        for (int j = i+1; j < array.count; j++) {
            
            // if里面的 '>' '<' 條件決定了排序的 升降
            if ([array[i] intValue] > [array[j] intValue]) {
                NSString *temp = array[j];
                array[j] = array[i];
                array[i] = temp;
            }
        }
    }
    
    NSLog(@"%@",array);
斐波那契算法【后一項(xiàng)等于前兩項(xiàng)之和】

import Foundation

/**
 a0 = 0
 a1 = 1
 a2 = a1 + a0
 a3 = a2 + a1
 a4 = a3 + a2
 a5 = a4 + a3
 ...
 
 */
/// MARK: - 斐波那契算法【后一項(xiàng)等于前兩項(xiàng)之和】
struct Algorithm {
    
    //后一項(xiàng)等于前兩項(xiàng)之和[遞歸法]
    func add(_ n: Int) -> Int {
        guard n != 0,n != 1 else {
            return n
        }
        
        return add(n - 1) + add(n - 2)
    }
    
    //后一項(xiàng)等于前兩項(xiàng)之和[數(shù)組法]
    func add_02(_ n: Int) -> Int {
        if n == 0 {
            return 0
        }
        
        if n == 1 {
            return 1
        }
        
        var array = [Int](repeating: 0, count: n + 1 )
        array[0] = 0
        array[1] = 1
        
        for i in 2...n {
            print("i = \(i)")
            array[i] = array[i - 1] + array[i - 2]
        }
        return array[n]
        
    }
    
    //后一項(xiàng)等于前兩項(xiàng)之和[中間變量交換法]
    func add_03(_ n: Int) -> Int {
        var a0 = 0
        var a1 = 1
        var an = 0
        
        var temp = 0
        for _ in 2...n {
            temp =  a1 + a0
            
            a0 = a1     //順序不能換
            a1 = temp
            
        }
        an = temp
        return an
    }
}


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末碟联,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子僵腺,更是在濱河造成了極大的恐慌鲤孵,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辰如,死亡現(xiàn)場離奇詭異普监,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門鹰椒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來锡移,“玉大人,你說我怎么就攤上這事漆际∠海” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵奸汇,是天一觀的道長施符。 經(jīng)常有香客問我,道長擂找,這世上最難降的妖魔是什么戳吝? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮贯涎,結(jié)果婚禮上听哭,老公的妹妹穿的比我還像新娘。我一直安慰自己塘雳,他們只是感情好陆盘,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著败明,像睡著了一般隘马。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上妻顶,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天酸员,我揣著相機(jī)與錄音,去河邊找鬼讳嘱。 笑死幔嗦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的呢燥。 我是一名探鬼主播崭添,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼寓娩,長吁一口氣:“原來是場噩夢啊……” “哼叛氨!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起棘伴,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬榮一對情侶失蹤寞埠,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后焊夸,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體仁连,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了饭冬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片使鹅。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖昌抠,靈堂內(nèi)的尸體忽然破棺而出患朱,到底是詐尸還是另有隱情,我是刑警寧澤炊苫,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布裁厅,位于F島的核電站,受9級(jí)特大地震影響侨艾,放射性物質(zhì)發(fā)生泄漏执虹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一唠梨、第九天 我趴在偏房一處隱蔽的房頂上張望袋励。 院中可真熱鬧,春花似錦当叭、人聲如沸插龄。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽均牢。三九已至,卻和暖如春才睹,著一層夾襖步出監(jiān)牢的瞬間徘跪,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來泰國打工琅攘, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留垮庐,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓坞琴,卻偏偏與公主長得像哨查,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子剧辐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

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