欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

歸并排序Merge Sort

系統 2129 0
      
         1
      
      
        //
      
      
        C語言實現
      
      
         2
      
      
         3
      
      
        void
      
       mergeSort(
      
        int
      
       array[],
      
        int
      
       first, 
      
        int
      
      
         last)


      
      
         4
      
      
        {


      
      
         5
      
      
        if
      
       (first < last)
      
        //
      
      
        拆分數列中元素只剩下兩個的時候,不再拆分
      
      
         6
      
      
            {


      
      
         7
      
      
        int
      
       mid = (first + last) / 
      
        2
      
      
        ;


      
      
         8
      
      
        //
      
      
        遞歸拆分數組
      
      
         9
      
      
                mergeSort(array, first, mid);


      
      
        10
      
               mergeSort(array, mid + 
      
        1
      
      
        , last);


      
      
        11
      
      
        //
      
      
        歸并兩個數組
      
      
        12
      
      
                merge(array, first, mid, last);     


      
      
        13
      
      
            }


      
      
        14
      
      
        }


      
      
        15
      
      
        16
      
      
        void
      
       merge(
      
        int
      
       array[], 
      
        int
      
       first,
      
        int
      
       mid,
      
        int
      
      
         last)


      
      
        17
      
      
        {


      
      
        18
      
      
        int
      
       i = first, j = mid + 
      
        1
      
      , k =
      
         first;


      
      
        19
      
      
        int
      
       temp[last + 
      
        1
      
      
        ];


      
      
        20
      
      
        21
      
      
        //
      
      
        從兩個數列的第一個開始判斷
      
      
        22
      
      
        while
      
       (i <= mid && j <=
      
         last)


      
      
        23
      
      
        if
      
       (array[i] <=
      
         array[j])


      
      
        24
      
                   temp[k ++] = array[i ++
      
        ];


      
      
        25
      
      
        else
      
      
        26
      
                   temp[k ++] = array[j ++
      
        ];


      
      
        27
      
      
        28
      
      
        //
      
      
        如果有剩余,補充進入數組
      
      
        29
      
      
        while
      
       (i <=
      
         mid)    


      
      
        30
      
               temp[k ++] = array[i ++
      
        ];


      
      
        31
      
      
        while
      
       (j <=
      
         last)


      
      
        32
      
               temp[k ++] = array[j ++
      
        ];


      
      
        33
      
      
        34
      
      
        //
      
      
        復制數組
      
      
        35
      
      
        while
      
       (first <=
      
         last)


      
      
        36
      
      
            {


      
      
        37
      
               array[first] =
      
         temp[first];


      
      
        38
      
               first ++
      
        ;


      
      
        39
      
      
            }


      
      
        40
      
       }
    
      
         1
      
      
        //
      
      
        Objective-C實現


      
      
         2
      
      
        //
      
      
        通過NSMutableArray的Category實現


      
      
         3
      
      
         4
      
      
        //
      
      
        .h文件
      
      
         5
      
      
        @interface
      
      
         NSMutableArray (ArraySort)


      
      
         6
      
      
         7
      
       - (
      
        void
      
      
        )mergeSort;


      
      
         8
      
      
         9
      
      
        @end
      
      
        10
      
      
        11
      
      
        //
      
      
        .m文件
      
      
        12
      
      
        13
      
      
        #import
      
      
        "
      
      
        NSMutableArray+ArraySort.h
      
      
        "
      
      
        14
      
      
        15
      
      
        @implementation
      
      
         NSMutableArray (ArraySort)


      
      
        16
      
      
        17
      
       - (
      
        void
      
      
        )mergeSort


      
      
        18
      
      
        {


      
      
        19
      
           [self sortByStartIndex:
      
        0
      
       endIndex:self.count - 
      
        1
      
      
        ];


      
      
        20
      
      
        }


      
      
        21
      
      
        22
      
       - (
      
        void
      
      )sortByStartIndex:(
      
        int
      
      )start endIndex:(
      
        int
      
      
        )end


      
      
        23
      
      
        {


      
      
        24
      
      
        if
      
       (start <
      
         end)


      
      
        25
      
      
            {


      
      
        26
      
      
        int
      
       mid = (start + end) / 
      
        2
      
      
        ;


      
      
        27
      
      
                [self sortByStartIndex:start endIndex:mid];


      
      
        28
      
               [self sortByStartIndex:mid + 
      
        1
      
      
         endIndex:end];


      
      
        29
      
      
                [self mergeByStartIndex:start midIndex:mid endIndex:end];


      
      
        30
      
      
            }


      
      
        31
      
      
        }


      
      
        32
      
      
        33
      
       - (
      
        void
      
      )mergeByStartIndex:(
      
        int
      
      )start midIndex:(
      
        int
      
      )mid endIndex:(
      
        int
      
      
        )end


      
      
        34
      
      
        {


      
      
        35
      
      
        int
      
       i = start,j = mid + 
      
        1
      
      
        ;


      
      
        36
      
           NSMutableArray *tempArray = [[NSMutableArray alloc] initWithCapacity:end + 
      
        1
      
      
        ];


      
      
        37
      
      
        38
      
      
        while
      
       (i <= mid && j <=
      
         end)


      
      
        39
      
      
        if
      
       ([[self objectAtIndex:i] integerValue] <=
      
         [[self objectAtIndex:j] integerValue])


      
      
        40
      
                   [tempArray addObject:[self objectAtIndex:i ++
      
        ]];


      
      
        41
      
      
        else
      
      
        42
      
                   [tempArray addObject:[self objectAtIndex:j ++
      
        ]];


      
      
        43
      
      
        44
      
      
        while
      
       (i <=
      
         mid)


      
      
        45
      
               [tempArray addObject:[self objectAtIndex:i ++
      
        ]];


      
      
        46
      
      
        while
      
       (j <=
      
         end)


      
      
        47
      
               [tempArray addObject:[self objectAtIndex:j ++
      
        ]];


      
      
        48
      
      
        49
      
      
        for
      
       (
      
        id
      
      
        object
      
      
        in
      
      
         tempArray)


      
      
        50
      
               [self replaceObjectAtIndex:start++ withObject:
      
        object
      
      
        ];


      
      
        51
      
      
        }


      
      
        52
      
      
        53
      
      
        @end
      
    

?

歸并排序Merge Sort


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲精品无码不卡在线播放he | 日本精品视频 | 最近最新中文字幕 | 91久久精品一区二区二区 | 免费一二区| 日韩久久久久久 | 福利精品| 成人毛片免费播放 | 特级做a爰片毛片免费看一区 | 亚洲日韩精品AV无码富二代 | 日本高清一区二区三区不卡免费 | 日本天堂免费a | 一区二区三区在线播放 | 欧美一区高清 | 日韩黄色在线视频 | 国产欧美一区二区精品久久久 | 亚洲国产精品久久久久久网站 | 香港全黄一级毛片在线播放 | 91国色 | 起视碰碰97摸摸碰碰视频 | 久久久免费视频观看 | 日韩欧美在线视频不卡免费视频 | 欧美日韩在线观看视频 | 99热精品在线| 欧美高清视频一区 | 欧美一区二区免费 | 国产日韩一区二区 | 亚洲第1页 | 婷婷激情网站 | 全黄裸片武则天一级第4季 亚洲一区国产 | 久久久久国产一区二区三区 | 九九热在线免费观看 | 日本精品a在线 | 丰满少妇久久久久久久 | 欧美日韩国产一区二区三区 | 国产一区高清 | 日产国产欧美视频一区精品 | 日韩精品无码一区二区三区 | aaa在线观看 | 成人片黄网站A片免费 | 青娱乐精品在线 |