常用的排序算法
创始人
2024-03-02 17:55:23

常用的排序算法

  1. 快速排序

    思路:以数组中的第一个元素作为基准,对数组进行调整,使得左边的元素都小于基本,右边的元素都大于等于基准;然后再分别对左右两边的数组进行如上方法的排序

    import numpy
    def partition(nums, l, r):t = nums[l]start = ll+=1while l <= r:while l<=r and nums[l] <= t:l += 1while l<=r and nums[r] >= t:r -= 1if l > r:breaknums[l], nums[r] = nums[r], nums[l]nums[start], nums[r] = nums[r], nums[start]return rdef quick_sort(nums, l, r):if l < r:parti_index = partition(nums, l, r)quick_sort(nums, l, parti_index - 1)quick_sort(nums, parti_index + 1, r)return numsif __name__ == '__main__':nums = numpy.random.randint(0, 20, 8)nums = list(nums)l = 0r = len(nums)-1nums_sort = quick_sort(nums, l, r)print(nums_sort)
    
  2. 归并排序

    思路:首先将数组拆分成单个元素,然后取一对元素进行合并,直到所有的元素都合并后,得到的就是排序后的结果

    def merge(arr1, arr2):i, j = 0, 0res = []while i
  3. 堆排序

    思路:首先建堆,将数组看作是二叉树,然后自底向上进行调整,使得根节点的值大于等于左右子树的值,最终二叉树的根是最大值;

    然后,将根节点从数组中移出,重新调整剩余数组的堆,每次调整后,堆顶元素就是当前数组的最大值。

    也就是说,建成堆之后,不断对堆顶进行调整,每次获取当前的最大值

    def heapify(arr, i, n):largest = ileft = 2*i+1right = 2*i+2if leftarr[largest]:largest = leftif rightarr[largest]:largest = rightif largest!=i:arr[largest],arr[i] = arr[i],arr[largest]heapify(arr, largest, n)def heap_sort(arr):n = len(arr)for i in range(n-1, -1,-1):heapify(arr,i,n)for j in range(n-1, 0, -1):arr[0], arr[j] = arr[j], arr[0]heapify(arr, 0, j)return arrimport numpy
    arr = numpy.random.randint(0,20,8)
    arr = list(arr)
    # arr = [3,6,2,4,7]
    print(arr)
    arr_sort = heap_sort(arr)
    print(arr_sort)
    
#快速排序衍生题目
def partition(arr, l, r):index = lp = arr[index]l +=1while(l<=r ):while(l<=r and arr[l]<=p):l+=1while(l<=r and arr[r]>=p):r-=1if(l>r):breakarr[l], arr[r] = arr[r], arr[l]arr[index], arr[r] = arr[r], arr[index]return r"""
最数组进行快速排序
"""
def quick_sort(arr, l, r):if(lk):r = m-1"""
求最小的K个数
"""
def cal_small_k_nums(arr, l, r, k):if(k>=len(arr)):return arrwhile(l<=r):m = partition(arr, l, r)if(m==k):return arr[0:k]elif(m>k):r = m-1elif(m

相关内容

热门资讯

中信证券:2026年度造纸行业... 转自:财联社【中信证券:2026年度造纸行业预计底部改善 金属包装行业将迎来春天】财联社11月21日...
财联社汽车早报11月21日 转自:财联社两部门发布《新能源汽车政府采购需求标准(征求意见稿)》11月20日,财政部会同工业和信息...
四川阆中警方凌晨通报 转自:北京日报客户端11月21日凌晨,四川省阆中市公安局发布“警情通报”:11月20日,阆中市一学生...
@近视的你 当心甜食正在悄悄损... 来源:央视新闻客户端 用眼过度、强光刺激……这些常见的视力“杀手”相信大家都不陌生但日常生活中有一个...
直击车展 | MoLA架构发布...   Hehson科技讯 11 月 21日上午消息,在华为乾崑生态大会上,华为智能汽车解决方案 BU ...