亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

歸并排序Merge Sort

系統 2060 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條評論
主站蜘蛛池模板: 天天舔天天干 | 伊人中文字幕在线 | 特级一级黄色片 | 国内精品综合九九久久精品 | 久久综合网址 | 亚洲一区二区三区高清不卡 | 91久久精一区二区三区大全 | 久久久久国产精品免费免费不卡 | 欧美成人午夜视频在线观看 | 美女被爆羞羞视频网站视频 | 久久99精品久久久久久噜噜丰满 | 午夜精品久久久久久久99 | 色婷婷婷丁香亚洲综合不卡 | 亚洲狠狠| 国产精品久久久久久免费 | 国产精品免费在线播放 | 日本最新免费二区三区 | 日韩精品一区二区三区高清 | 五月久久亚洲七七综合中文网 | 久久成人亚洲 | 日日操夜夜 | 日本高清免费不卡视频 | 日本一级特黄毛片免费视频 | 欧美日韩亚洲精品一区二区 | 国产欧美日韩高清专区手机版 | 午夜色大片在线观看 | 免费精品国产自产拍观看 | 国产一级精品视频 | 成人欧美一区二区三区黑人免费 | 91精品国产露脸在线 | 伊人一区二区三区 | 国产a毛片高清视 | 久久婷婷五综合一区二区 | 成人影院在线观看 | 亚洲成a人v | 一级作爱视频免费观看 | 91精品一区二区三区久久久久 | 国产成人午夜片在线观看 | 深夜网站在线观看 | 成人免费在线视频 | 国产日韩网站 |