例11 整数排序

蓝咒 提交于 2019-12-03 21:30:21
#给出一组整数,将其按照升序排序
#例如给出[3,2,1,4,5],排序后的结果为[1,2,3,4,5]
#参数A是一个整数数组
#返回一个整数数组

class Solution:
    def sortIntegers2(self,A):
        self.quickSort(A,0,len(A)-1)
    def quickSort(self,A,start,end):
        if start>=end:
            return
        left,right=start,end
        pivot=A[int((start+end)/2)]
        while left<=right:
            while left<=right and A[left] < pivot:
                left += 1
            while left<=right and A[right]>pivot:
                right-=1
            if left<=right:
                A[left],A[right]=A[right],A[left]
                left+=1
                right-=1
        self .quickSort(A,start,right)
        self.quickSort(A,left,end)

#主函数
if __name__ == "__main__":
    A = [3,2,1,4,5]
    print('初始数组:',A)
    solution = Solution()
    solution.sortIntegers2(A)
    print('快速排序:',A)
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!