真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

快速排序的python實(shí)現(xiàn)


def sort1(arr):
    """
    思路:
    以arr[0]為pivot
    以arr長度小于等于1為邊界,返回arr
    分別將小于pivot、等于pivot、大于pivot的分類
    遞歸處理兩邊的分類,將結(jié)果組合返回
    :param arr:
    :return:
    """
    if len(arr) <= 1:
        return arr
    pivot = arr[0]
    left = [x for x in arr if x < pivot]
    middle = [x for x in arr if x == pivot]
    right = [x for x in arr if x > pivot]
    return sort1(right) + middle + sort1(left)

def sort2(arr, arr_l, arr_r):
    """
    思路:
    以arr[arr_r]為pivot
    以arr長度小于等于1為邊界,直接返回
    左游標(biāo)從arr_l到arr_r移動,當(dāng)arr[左游標(biāo)]<=pivot時(shí)進(jìn)行處理:
        if arr[左游標(biāo)]<=arr[r]:
            if 左游標(biāo) == arr_r:
                遞歸處理 arr_l到arr_r-1
            else:
                右游標(biāo)從arr_r-1到左游標(biāo)移動:
                    if 右游標(biāo)>左游標(biāo) and arr[右游標(biāo)]>pivot:
                        交換arr[左游標(biāo)] arr[右游標(biāo)]
                        跳出右游標(biāo)的循環(huán)
                    elif 右游標(biāo) == 左游標(biāo):
                        交換arr[右游標(biāo)] pivot
                        遞歸處理 arr_l到(右游標(biāo)-1)
                        遞歸處理 (右游標(biāo)+1)到arr_r

    :param arr:
    :param arr_l:
    :param arr_r:
    :return:
    """
    if len(arr) <= 1:
        return
    for left in range(arr_l, arr_r+1):
        if arr[left] <= arr[arr_r]:
            if left == arr_r:
                sort2(arr, arr_l, arr_r-1)
            else:
                for right in range(arr_r-1, left-1, -1):
                    if right > left and arr[right] > arr[arr_r]:
                        arr[right], arr[left] = arr[left], arr[right]
                        break
                    elif right == left:
                        arr[right], arr[arr_r] = arr[arr_r], arr[right]
                        sort2(arr, arr_l, right-1)
                        sort2(arr, right+1, arr_r)
                        return

def sort(arr, method=2):
    if method == 1:
        return sort1(arr)
    elif method == 2:
        sort2(arr, 0, len(arr)-1)
        return arr

if __name__ == "__main__":
    l = [5, 2, 7, 8, 6, 1, 4, 9, 10, 1, 2, 3, 4]
    print(sort(l))

分享標(biāo)題:快速排序的python實(shí)現(xiàn)
URL地址:http://weahome.cn/article/pcjcii.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部