快速排序的python实现
admin
2023-07-02 12:04:58
0

def sort1(arr):
    """
    思路:
    以arr[0]为pivot
    以arr长度小于等于1为边界,返回arr
    分别将小于pivot、等于pivot、大于pivot的分类
    递归处理两边的分类,将结果组合返回
    :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为边界,直接返回
    左游标从arr_l到arr_r移动,当arr[左游标]<=pivot时进行处理:
        if arr[左游标]<=arr[r]:
            if 左游标 == arr_r:
                递归处理 arr_l到arr_r-1
            else:
                右游标从arr_r-1到左游标移动:
                    if 右游标>左游标 and arr[右游标]>pivot:
                        交换arr[左游标] arr[右游标]
                        跳出右游标的循环
                    elif 右游标 == 左游标:
                        交换arr[右游标] pivot
                        递归处理 arr_l到(右游标-1)
                        递归处理 (右游标+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))

相关内容

热门资讯

日本首次通过北约清单军援乌克兰 据凤凰卫视报道,日本外务省5月29日宣布,首次通过北约“乌克兰优先需求清单”框架,向乌克兰提供约22...
黑龙江大学科研成果首次被国际数... 近日,黑龙江大学计算机与大数据学院(网络安全学院)朱敬华教授团队在数据挖掘与知识发现领域取得重要科研...
原创 深... 提到深圳的科技创新,你脑海里是不是立刻蹦出南山区的粤海街道? 但可能从今年开始,这个答案要改写了。 ...
一天吃透一个行业09:液冷概念... 来源:市场资讯 (来源:券研社) 一、为什么液冷已成AI算力"刚需"? 芯片功耗突破风冷极限。英伟达...
2026年6月安卓摄影新选择:... 2026年6月安卓摄影新选择:CCD质感手机推荐 2026年6月安卓摄影新选择:CCD质感手机推荐 ...
总书记的人民情怀 | “要坚持... 本报记者 吴 丹原标题:“要坚持健康第一的教育理念”(总书记的人民情怀)
菲律宾防长“装可怜”:中美实力... 【文/观察者网 齐倩】菲律宾政府近年来仗着美国撑腰,在南海议题上“兴风作浪”。中美紧张关系缓和后,菲...
老板燃气灶一直报警是怎么回事 老板燃气灶一直报警是怎么回事原因可能有以下几点:1.熄火保护电路故障造成误报警,导致其长鸣声不断;2...
老板燃气灶一直报警怎么回事 原因可能有以下几点:1.熄火保护电路故障造成误报警,导致其长鸣声不断;2.燃气意外熄灭导致熄火保护功...
燃气灶报警器一直闪灯 这种情况原因有很多种,1、可能是某个零件出现了问题。2、当工业环境中燃气气体泄露,燃气报警器检测到气...