首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  算法

关于快排 quicksort 的两种写法

  •  
  •   Alpacino · 120 天前 · 528 次点击
    这是一个创建于 120 天前的主题,其中的信息可能已经有所发展或是发生改变。

    写法 1 i = low 返回 low

    def partition(arr,low,high): 
        i = low      # index of smaller element 
        pivot = arr[high]     # pivot
        for j in range(low , high): 
            if   arr[j] <= pivot:
                arr[i],arr[j] = arr[j],arr[i] 
                i = i+1
        arr[i],arr[high] = arr[high],arr[i] 
        return i
    
    def quickSort(arr,low,high): 
        if low < high: 
            pi = partition(arr,low,high) 
            quickSort(arr, low, pi-1) 
            quickSort(arr, pi+1, high) 
    

    写法 2 i = (low-1)开始 返回 i + 1

    def partition(arr,low,high): 
        i = ( low-1 )         # index of smaller element 
        pivot = arr[high]     # pivot 
      
        for j in range(low , high): 
            if   arr[j] <= pivot: 
                i = i+1 
                arr[i],arr[j] = arr[j],arr[i] 
      
        arr[i+1],arr[high] = arr[high],arr[i+1] 
        return ( i+1 ) 
      
    def quickSort(arr,low,high): 
        if low < high: 
            pi = partition(arr,low,high) 
            quickSort(arr, low, pi-1) 
            quickSort(arr, pi+1, high) 
    
    2 回复  |  直到 2019-07-16 15:14:24 +08:00
        1
    Alpacino   120 天前
    这两个写法有什么区别吗?
    是处理 edge case 上的不同?
        2
    billc   119 天前
    茴香豆的茴有 4 种写法。

    --------------------------------------------

    正经回答:
    没差别,你把下面所有的 i,替换成 i-1,和上面的完全一样
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3284 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 21ms · UTC 04:41 · PVG 12:41 · LAX 20:41 · JFK 23:41
    ♥ Do have faith in what you're doing.