NC140 排序、NC119 最小的K个数、

NC140题:给定一个长度为 n 的数组,请你编写一个函数,返回该数组按升序排序后的结果。

#快速排序
class Solution:
    def MySort(self , arr: List[int]) -> List[int]:
        self.quick(arr,0,len(arr)-1)
        return arr
    def quick(self,arr,st,end):
        if st>=end: return 
        left, right = st, end #左右指针
        tmp = arr[(st + end) // 2]#基准元素
        while left<=right:
            while left<=right and arr[left]tmp:#直到找到小于tmp的
                right-=1
            if left <= right:
                arr[left], arr[right] = arr[right], arr[left]
                left+=1
                right-=1
        self.quick(arr,st,right)#对左子组快排
        self.quick(arr,left,end)#对右子组快排

 各种排序:排序_牛客题霸_牛客网 (nowcoder.com)icon-default.png?t=M3K6https://www.nowcoder.com/practice/2baf799ea0594abd974d37139de27896?tpId=196&tqId=37185&rp=1&ru=/exam/oj&qru=/exam/oj&sourceUrl=%2Fexam%2Foj%3Fpage%3D1%26pageSize%3D50%26search%3D%26tab%3D%25E7%25AE%2597%25E6%25B3%2595%25E7%25AF%2587%26topicId%3D196&difficulty=undefined&judgeStatus=undefined&tags=&title=

 NC119 题:给定一个长度为 n 的可能有重复值的数组,找出其中不去重的最小的 k 个数。

#直接排序 取前k个 O(nlog2n) O(1)
#优化 堆排序 O(nlog2k) O(k)
        1.将n个数字放入堆中
        2.然后如果此时堆中的数字超过k个,那么就说明此时堆中最大的数字一定不属于最小的k个数字里面,所以我们可以将堆顶的元素进行出堆。
        3.堆变为数组

import heapq#小根堆
class Solution:
    def GetLeastNumbers_Solution(self , input: List[int], k: int) -> List[int]:
        res,q=[],[]
        if len(input)k:#保证是k个较小元素在大根堆中
                heapq.heappop(q)
        for i in range(k):#堆中元素取出入数组
            res.append(-1*q[0])
            heapq.heappop(q)
        return res

NC119 题:有一个整数数组,请你根据快速排序的思路,找出数组中第 k 大的数。

 #直接排序 O(n*lgn)

class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        a.sort(reverse = True)
        return a[K-1] 

 #快速排序:每次移动,可以找到一个标杆元素p,然后将大于它的移到左边,小于它的移到右边。
         快排+二分 时间复杂度 O(nlogn),空间复杂度 O(1)
         当right-p小于k的时候,在后半部分搜索,
         当right-p大于k的时候,在前半部分搜索。

class Solution:
    def findKth(self , a: List[int], n: int, k: int) -> int:
        return self.find(a,0,n-1,k)
    def find(self,a,left,right,k):
        p = self.quick(a,left,right)
        if p== k-1:
            return a[p]
        elif p=tmp:#直到找到基准左边小于tmp的
                left+=1
            a[right]=a[left]
        a[left]=tmp
        return left

你可能感兴趣的:(剑指offer,排序,算法)