0x3f 第36天 外卖8,9,树

1.二叉搜索树中第k小的元素

1.核心思路:中序

2.中序出来的就是123456

3.所以每次左子树遍历之后,k-1 当k==0的时候,正好就是顺序的第k个

4.终止条件是遍历到 None或者k==0也就是提前找到了第k个,就直接结束,不用再找了

❌ 情况 1:不加 k==0 这个终止条件,代码会怎么样?

如果终止条件只写 if node is None: return,代码逻辑上能得到正确答案,但会做大量「无用功」:

  • 哪怕找到了目标节点(k=0),递归依然会继续执行:遍历完当前节点的右子树、遍历完父节点的右子树、遍历完整棵树的所有剩余节点;

  • 比如找第 2 小的节点,找到后还要遍历后面所有节点,时间复杂度从最优的 O(H+k) 变成了最差的 O(N)(N 是总节点数),效率暴跌!

    class Solution:
    def kthSmallest(self, root: Optional[TreeNode], k: int) -> int:
    ans = 0
    def dfs(node):
    nonlocal ans,k
    if node is None or k==0:
    return
    dfs(node.left)
    k-=1
    if k==0:
    ans = node.val
    dfs(node.right)
    dfs(root)
    return ans

2.二叉树展开为链表

  • 展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左子指针始终为 null

因为要求展开后的单链表应该与二叉树 先序遍历 顺序相同

那使用头插法就得用后序遍历

定义一个全局变量头head,根据要求,后序的root的right指向head,head再指向root,就完成了头插法,不好理解的话,画个图一下就明白了

相关推荐
晨非辰2 小时前
C++波澜壮阔40年|类和对象篇:拷贝构造与赋值重载的演进与实现
运维·开发语言·c++·人工智能·后端·python·深度学习
Remember_9932 小时前
【LeetCode精选算法】双指针专题一
java·数据结构·算法·leetcode
天才测试猿2 小时前
Chrome浏览器+Postman做接口测试
自动化测试·软件测试·python·测试工具·测试用例·接口测试·postman
zckui2 小时前
conda常用命令
python·conda
jonyleek2 小时前
开源APS排产系统,出货计划如何成为企业降本增效的关键?
算法·开源·私有化部署·软件开发·生产排产·aps排产系统
张3蜂2 小时前
Label-Studio图片标注初体验
python·开源
hetao17338372 小时前
2026-01-16~19 hetao1733837 的刷题笔记
c++·笔记·算法
深蓝电商API2 小时前
Scrapy LinkExtractor参数详解与复杂链接提取
爬虫·python·scrapy
我是一只小青蛙8882 小时前
Python入门指南:从安装到Hello World
python