08头条实习生面试_字典序的第K小数字

这篇博客探讨了LeetCode中的440题,即如何找到字典序的第K小数字。通过分析问题转化为先序遍历一个不完全的十叉树,并详细解释了利用十叉树结构解决问题的思路,包括计算同一层相邻节点间子节点个数的步骤,以及如何递归地调整当前节点和k值来找到目标数字。
摘要由CSDN通过智能技术生成

LeetCode(440) 字典序的第K小数字

思路:

其实这是一个"十叉树",如下图:

1)每个节点的子节点可以有十个,比如节点1的子节点可以是10~19、节点2的子节点的可以是20~29、。。。

但是由于n大小的限制,构成的并不是一个"满十叉树"。

2)分析题目中给的例子可以知道,数字1的子节点有4个(10,11,12,13),而后面的数字2到9都没有子节点,

那么这道题实际上就变成了一个先序遍历十叉树的问题。

3)那么,难点就变成了 计算出同一层两个相邻的节点的子节点的个数,也就是代码中的steps

  3.1)当前节点为 curr  (从curr = 1 开始),则同一层的下一个节点为 curr+1;

  3.2)计算节点 curr到节点curr+1之间的子节点个数steps

     3.2.1)如果子节点个数 大于 k,说明第k小的数一定在子节点中,

              继续向下一层寻找:curr *=10

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值