python实现常见的排序方法

冒泡排序

循环遍历,一次比较两个元素,如果他们循序错误就把他们交换过来,重复进行,直到没有再需要交换的。

# 实现代码
def maopao_sort(target_list):
    for item in range(len(target_list) - 1):
        for i in range(len(target_list) - item -1):
            if target_list[i] > target_list[i+1]:
                target_list[i],target_list[i+1] = target_list[i+1],target_list[i]
    return target_list

选择排序

假设第一个元素最小,然后与后面元素比较,如果后面的比第一个元素小,就将他们换一个位置,并且标记这个为最小元素,继续与后面比较,直到找到最小元素,这时候最小元素就在第一个,以此类推找到第二小的排在第二个位置,直到最后。

# 实现代码
def select_sort(target_list):
    for item in range(len(target_list) - 1):
        min_element = item
        for i in range(item + 1, len(target_list)):
            if target_list[i] < target_list[min_element]:
                min_element = i
            if item != min_element:
                target_list[i],target_list[min_element] = target_list[min_element],target_list[i]
    return target_list

快速排序

挑出第一个元素作为基准,拿数组最后一个元素与这个数比较,如果比它大,则最后一个数不动,再拿倒数第二个数与它比较,如果比这个数小,则将倒数第二个数放到挑出这个数的索引处,这时候倒数第二个位置空出来了,然后拿前面第二个数与这个数比较,如果比它小则不动,拿第三个数与这个数比较,如果比它大,则将第三个数放到倒数第二个空位置处,以此类推,直到这个数前面的数都比它小,后面的数都比它大,然后利用递归,把小于基准元素的子数列和大于基准元素的子数列排序。

# 实现代码
def sub_sort(low,high,target_list):
    key = target_list[low]
    while low < high:
        while low < high and target_list[high] >= key:
            high -= 1
        target_list[low] = target_list[high]
        while low < high and target_list[low] < key:
            low += 1
        target_list[high] = target_list[low]
    target_list[low] = key
    return low
def quick_sort(low,high,target_list):
    if low <= high:
        key = sub_sort(low,high,target_list)
        quick_sort(low,key-1,target_list)
        quick_sort(key+1,high,target_list)
    return target_list

归并排序

两个有序列表,依次比较,新开一个空列表,哪一个小将哪一个元素添加到空列表里,如何实现两个有序列表?利用递归不断平分分解,直到只有两个元素,两个元素就好比两个有序数组,然后合并,如下图。

# 实现代码
def merge(low, mid, high, target_list):
    i = low
    j = mid + 1
    tmp = []
    while i <= mid and j <= high:
        if target_list[i] < target_list[j]:
            tmp.append(target_list[i])
            i += 1
        else:
            tmp.append(target_list[j])
            j += 1
    while i <= mid:
        tmp.append(target_list[i])
        i += 1
    while j <= high:
        tmp.append(target_list[j])
        j += 1
    target_list[low:high + 1] = tmp
def merge_sort(low, high, target_list):
    if low < high:
        mid = (low + high) // 2
        merge_sort(low, mid, target_list)
        merge_sort(mid + 1, high, target_list)
        merge(low, mid, high, target_list)
    return target_list
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值