91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

劍指offer:最小的k個數

發布時間:2020-04-28 14:59:00 來源:網絡 閱讀:517 作者:Jayce_SYSU 欄目:編程語言

題目描述
輸入n個整數,找出其中最小的K個數。例如輸入4,5,1,6,2,7,3,8這8個數字,則最小的4個數字是1,2,3,4,。

# -*- coding: utf-8 -*-
# @Time         : 2019-07-08 21:09
# @Author       : Jayce Wong
# @ProjectName  : job
# @FileName     : getLeastNumbers.py
# @Blog         : https://blog.51cto.com/jayce1111
# @Github       : https://github.com/SysuJayce

class Solution:
    """
    從數組中尋找最小的k個數字,一般來說最直接的做法就是先將這個數組排序,然后取最小的k個數字即可。
    但是這樣做的時間復雜度為O(nlogn)

    解法1:
    借鑒快排中partition()的做法,因為partition()每次可以確定一個下標的正確元素,并保證其左右與其
    大小關系有序。所以只要我們通過partition()確定了下標為k-1的元素,那么其左邊都是小于該元素的。
    時間復雜度為O(n)

    解法2:
    可以維護一個容量為k的容器,然后遍歷整個數組,如果遇到比容器中最大值要小的元素,那么就將這個元素
    替換容器中的最大值。時間復雜度為O(nlogk)
    """
    def GetLeastNumbers_Solution1(self, tinput, k):
        if k <= 0 or k > len(tinput):
            return []

        ans = tinput[:k]
        for i in range(k, len(tinput)):
            if tinput[i] < max(ans):
                ans.remove(max(ans))
                ans.append(tinput[i])

        return sorted(ans)

    def GetLeastNumbers_Solution2(self, tinput, k):
        def partition(begin, end):
            pos = begin
            for i in range(begin, end):
                if tinput[i] < tinput[end]:
                    tinput[i], tinput[pos] = tinput[pos], tinput[i]
                    pos += 1
            tinput[end], tinput[pos] = tinput[pos], tinput[end]
            return pos

        if k <= 0 or k > len(tinput):
            return []

        start, stop = 0, len(tinput) - 1
        idx = partition(start, stop)
        while idx != k - 1:
            if idx > k:
                stop = idx - 1
            else:
                start = idx + 1
            idx = partition(start, stop)

        return sorted(tinput[: k])

def main():
    nums = [4, 5, 1, 6, 2, 7, 3, 8]
    k = 4
    solution = Solution()
    print(solution.GetLeastNumbers_Solution2(nums, k))

if __name__ == '__main__':
    main()
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

金坛市| 静海县| 开远市| 垫江县| 建阳市| 丰城市| 陕西省| 穆棱市| 石门县| 文昌市| 小金县| 鲜城| 兴国县| 永平县| 南投县| 平舆县| 香格里拉县| 福贡县| 珠海市| 茶陵县| 普陀区| 巴彦淖尔市| 高尔夫| 西乡县| 诸城市| 平度市| 马边| 广东省| 铜陵市| 顺义区| 岐山县| 莱西市| 兴义市| 德清县| 新源县| 宝丰县| 罗平县| 团风县| 靖远县| 闵行区| 新宁县|