题解 | #最小的K个数#

最小的K个数

https://www.nowcoder.com/practice/6a296eb82cf844ca8539b57c23e6e9bf

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param input int整型一维数组 
# @param k int整型 
# @return int整型一维数组
#
class SortTree:
    def __init__(self,val:int):
        self.value = val
        self.left = None
        self.right= None
class Solution:
    def parseTree(self,root,k):
        print(root.value,k)
        rst=[]
        if root.left is not None:
            l,k = self.parseTree(root.left,k)
            rst += l
            if k == 0:
                return rst,k
        rst.append(root.value)
        k -= 1
        if k == 0:
            return rst,k
        if root.right is not None:
            l,k = self.parseTree(root.right,k)
            rst += l
            if k == 0:
                return rst,k
        return rst,k
        
    def add(self, root, node):
        if node > root.value:
            if root.right is not None:
                self.add(root.right,node)
            else:
                root.right = SortTree(node)
        else:
            if root.left is not None:
                self.add(root.left, node)
            else:
                root.left = SortTree(node)

    def GetLeastNumbers_Solution(self , input: List[int], k: int) -> List[int]:
        # write code here
        # 建二叉排序树,然后输出最小的4个数
        if len(input) == 0 or k == 0:
            return []
        r = root = SortTree(input[0])
        for i in range(1,len(input)):
            # 建树的过程也需要遍历
            root = r
            self.add(root,input[i])

        # 中序遍历树,计数:k
        rst,k=self.parseTree(r,k)
        return rst

全部评论

相关推荐

牛客266927136号:为啥实习经历写这么少,项目经历反而大写特写,最重要的还是实习经历吧,写具体点,什么场景下做了什么事,解决了什么问题,优化了什么场景,性能提升了多少多少
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-25 19:15
点赞 评论 收藏
分享
VirtualBool:都去逗他了?
点赞 评论 收藏
分享
qq乃乃好喝到咩噗茶:院校后面加上211标签,放大加粗,招呼语也写上211
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务