快速排序

import numpy as np
import numpy


def qucikSort(nums,left=None,right=None):
    left = 0 if not isinstance(left,(int,float)) else left
    right = len(nums)-1 if not isinstance(right,(int,float)) else right
    if left >= right:
        return

    mid = partion(nums,left,right)
    qucikSort(nums,left,mid-1)
    qucikSort(nums,mid+1,right)
    return nums

def partion(nums,left,right):
    pivot = numpy.random.randint(left,right)
    nums[pivot],nums[left] = nums[left],nums[pivot]
    index = left+1
    i = index
    while i<=right:
        if nums[i]<nums[left]:
            nums[i],nums[index] = nums[index],nums[i]
            index +=1
        i +=1
    nums[index-1],nums[left] = nums[left],nums[index-1]
    return index-1
res = qucikSort([4,3,5,9,6,1,23,453,13,1])
print(res)

posted @   爱吃西瓜的菜鸟  阅读(16)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
点击右上角即可分享
微信分享提示