python对数组的快排 加注释

原理参考此图解法:

图解数组的快速排序【附源代码】_实现对一个数组的快速排序-CSDN博客

python代码:

法一:原地改数组

python 复制代码
# 利用快速排序实现数组的快排 降序 升序同理

def fastSort(arr,Left,Right):
  # 递归函数实现数组的快排
  # 终止条件
  if Right < Left:
    return
  # 需要记录当前的left和right 因为这样在下层递归中知道左区间左侧 和右区间右侧
  i = Left
  j = Right
  # 单层递归逻辑 快排 → 找到一个基准 让数组左边大于基准 数组右边小于基准
  tmp = arr[0]    #一般以数组的第一个元素作为基准
  # 只要左指针位置 小于 右指针位置时 都分别左右指针移动 直至重合 说明单次快排结束
  while i < j:
    # 移动右指针 直至找到比tmp大的元素 赋给右指针(因为当前右指针位置所对应值是tmp或比tmp大的(在递归中) 要替换掉)
    while i < j and arr[j] <= tmp:
      j -= 1
    arr[i] = arr[j]
    # 移动左指针 直至找到比tmp小的元素 赋给右指针(因为当前右指针位置所对应值是比tmp大的 要替换掉)
    while i < j and arr[i] >= tmp:
      i += 1
    arr[j] = arr[i]
  # 跳出了循环说明i == j
  arr[i] = tmp
  # 此时arr[i] 的左边都比tmp大 右边都比tmp小 但顺序还是不知道的,因此用递归
  fastSort(arr,Left, i-1)  # 这里隐藏了个回溯过程 i还是没变
  fastSort(arr,i+1,Right)

arr = [2,3,5,6,4,1]
fastSort(arr,0,len(arr)-1)
print(arr)
  
#结果 [6, 5, 4, 3, 2, 1]

法二:开辟新的空间

python 复制代码
def fastSort(arr):
  # 终止条件
  if len(arr) == 1:
    return arr
  # 单层递归逻辑
  small, cur, big = [], [], []
  # 以数组中第一个元素为基准
  base = arr[0]
  for num in arr:
    if num > base:
      big.append(num)
    elif num < base:
      small.append(num)
    else:
      cur.append(num)
  small = fastSort(small)
  big = fastSort(big)
  return small + cur + big


arr = [2,5,6,1,2,3]
print(fastSort(arr))

# 结果 [1, 2, 2, 3, 5, 6]
相关推荐
用户00993831430110 分钟前
代码随想录算法训练营第十三天 | 二叉树part01
数据结构·算法
shinelord明14 分钟前
【再谈设计模式】享元模式~对象共享的优化妙手
开发语言·数据结构·算法·设计模式·软件工程
薄荷故人_39 分钟前
从零开始的C++之旅——红黑树及其实现
数据结构·c++
努力学习编程的伍大侠1 小时前
基础排序算法
数据结构·c++·算法
XiaoLeisj1 小时前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Jackey_Song_Odd2 小时前
C语言 单向链表反转问题
c语言·数据结构·算法·链表
乐之者v3 小时前
leetCode43.字符串相乘
java·数据结构·算法
A懿轩A4 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
️南城丶北离5 小时前
[数据结构]图——C++描述
数据结构··最小生成树·最短路径·aov网络·aoe网络
✿ ༺ ོIT技术༻5 小时前
C++11:新特性&右值引用&移动语义
linux·数据结构·c++