剑指offer-62:二叉树的第k个结点

二叉搜索树的第k个结点

https://www.nowcoder.com/practice/ef068f602dde4d28aab2b210e859150a?tpId=13&&tqId=11215&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

题目:给定一棵二叉搜索树,请找出其中的第k小的TreeNode结点。
示例1
输入:{5,3,7,2,4,6,8},3
返回值:{4}
说明:按结点数值大小顺序第三小结点的值为4

思路:
1:二叉搜索树的性值是,左节点<根节点<右节点,所以我们可以通过中序遍历,将每个结点装入一个数组当中,然后通过返回数组的第k个结点来解题

function KthNode(pRoot, k)
{
    // write code here
    let arr = []
    function xianxubianli(root){
        if(!root) return 
        xianxubianli(root.left)
        arr.push(root)
        xianxubianli(root.right)
    }
    xianxubianli(pRoot)
    return arr[k-1]
}
全部评论

相关推荐

已注销:bro不如吃顿疯狂星期四
点赞 评论 收藏
分享
09-01 11:31
门头沟学院 Java
buul:七牛云的吧,感觉想法是好的,但是大家没那么多时间弄他这个啊。。。不知道的还以为他是顶尖大厂呢还搞比赛抢hc,只能说应试者的痛苦考察方是无法理解的,他们只会想一出是一出
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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