08-二叉树的下一个节点

嗯。。。这道题,LeetCode没有收录,只有牛客收录了,但是。。牛客那里做这道题用不了go,只能选其他语言,我也不知道咋回事。。。好久没用java写过算法题了。。。

这道题对当前节点要分几种情况考虑

1:当前节点有右子节点,那么肯定有下一个节点了,就是右子树的最左节点,假如该右子树没有左子树,那么该节点就是下一节点

2:当前节点没有右子树,这里有几种可能,当前节点是父节点的左节点,那么此下一个节点就是父节点

3:当前节点没有右子树,并且是父节点的右节点,这种情况下,只有一个可能,那就是父节点要是爷爷节点的左子树,这样的话爷爷节点就是当前节点的下一节点,如果发现父节点也是爷爷节点的右子树,那么再向上查询,如果最后节点为空了都没发现符合条件的节点,那么当前节点没有下一节点

代码如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值