zoukankan      html  css  js  c++  java
  • 排序算法Nb三人组-归并排序

    归并排序只能对两个已经有序的列表进行合并排序,所以要我们自己创建出两个有序列表。最后在进行合并.

    def merge2list(li1, li2):
        li = []
        i = 0
        j = 0
        while i < len(li1) and j < len(li2):
            if li1[i] <= li2[j]:
                li.append(li1[i])
                i += 1
            else:
                li.append(li2[j])
                j += 1
        while i < len(li1):
            li.append(li1[i])
            i += 1
        while j < len(li2):
            li.append(li2[j])
            j += 1
        return li
    def merge(li, low, mid, high):
        # 列表两段有序: [low, mid] [mid+1, high]
        i = low
        j = mid + 1
        li_tmp = []
        while i <= mid and j <= high:
            if li[i] <= li[j]:
                li_tmp.append(li[i])
                i += 1
            else:
                li_tmp.append(li[j])
                j += 1
        while i <= mid:
            li_tmp.append(li[i])
            i += 1
        while j <= high:
            li_tmp.append(li[j])
            j += 1
        # li_tmp[0:high-low+1] li[low:high+1]
        for i in range(low, high+1):
            li[i] = li_tmp[i-low]
    def _merge_sort(li, low, high): #排序li的low到high的范围
        if low < high:
            mid = (low + high) // 2
            _merge_sort(li, low, mid)
            _merge_sort(li, mid+1, high)
            # print(li[low:mid + 1], li[mid + 1:high + 1])
            merge(li, low, mid, high)
            # print(li[low: high + 1])
  • 相关阅读:
    精选30道Java笔试题解答
    ASM
    Java Decompiler Plugin For Eclipse IDE
    AMQ5540, AMQ5541 and AMQ5542, application did not supply a user ID and password, 2035 MQRC_NOT_AUTHORIZED
    Shell脚本中的export
    Linux set unset命令
    shell中${}的妙用
    ubuntu alsa2
    ubuntu alsa
    计算机启动boot
  • 原文地址:https://www.cnblogs.com/Treasuremy/p/10432713.html
Copyright © 2011-2022 走看看