C++怎么解决每个节点的右向指针问题


这篇文章主要介绍“C++怎么解决每个节点的右向指针问题”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++怎么解决每个节点的右向指针问题”文章能帮助大家解决问题。You are given aperfect binary treewhereall leaves are on the same level, and every parent has two children. The binary tree has the following definition:struct Node {
int val;
Node *left;
Node *right;
Node *next;
}Populate each next pointer to point to its next right node. If there is no next right node, the next pointer should be set toNULL.Initially, all next pointers 香港云主机 are set toNULL.Example:Input: {“$id”:”1″,”left”:{“$id”:”2″,”left”:”$id”:”3″,”left”:null,”next”:null,”right”:null,”val”:4},”next”:null,”right”:{“$id”:”4″,”left”:null,”next”:null,”right”:null,”val”:5},”val”:2},”next”:null,”right”:{“$id”:”5″,”left”:{“$id”:”6″,”left”:null,”next”:null,”right”:null,”val”:6},”next”:null,”right”:{“$id”:”7″,”left”:null,”next”:null,”right”:null,”val”:7},”val”:3},”val”:1}Output: {“$id”:”1″,”left”:{“$id”:”2″,”left”:{“$id”:”3″,”left”:null,”next”:{“$id”:”4″,”left”:null,”next”:{“$id”:”5″,”left”:null,”next”:{“$id”:”6″,”left”:null,”next”:null,”right”:null,”val”:7},”right”:null,”val”:6},”right”:null,”val”:5},”right”:null,”val”:4},”next”:{“$id”:”7″,”left”:{“$ref”:”5″},”next”:null,”right”:{“$ref”:”6″},”val”:3},”right”:{“$ref”:”4″},”val”:2},”next”:null,”right”:{“$ref”:”7″},”val”:1}Explanation: Given the above perfect binary tree (Figure A), your function should populate each next pointer to point to its next right node, just like in Figure B.Note:You may only use constant extra space.Recursive approach is fine, implicit stack space does not count as extra space for this problem.这道题实际上是树的层序遍历的应用,可以参考之前的博客Binary Tree Level Order Traversal,既然是遍历,就有递归和非递归两种方法,最好两种方法都要掌握,都要会写。下面先来看递归的解法,由于是完全二叉树,所以若节点的左子结点存在的话,其右子节点必定存在,所以左子结点的 next 指针可以直接指向其右子节点,对于其右子节点的处理方法是,判断其父节点的 next 是否为空,若不为空,则指向其 next 指针指向的节点的左子结点,若为空则指向 NULL,代码如下:解法一:对于非递归的解法要稍微复杂一点,但也不算特别复杂,需要用到 queue 来辅助,由于是层序遍历,每层的节点都按顺序加入 queue 中,而每当从 queue 中取出一个元素时,将其 next 指针指向 queue 中下一个节点即可,对于每层的开头元素开始遍历之前,先统计一下该层的总个数,用个 for 循环,这样当 for 循环结束的时候,该层就已经被遍历完了,参见代码如下:解法二:我们再来看下面这种碉堡了的方法,用两个指针 start 和 cur,其中 start 标记每一层的起始节点,cur 用来遍历该层的节点,设计思路之巧妙,不得不服啊:解法三:关于“C++怎么解决每个节点的右向指针问题”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注开发云行业资讯频道,小编每天都会为大家更新不同的知识点。

相关推荐: 怎么解决win8自动断网问题

这篇文章将为大家详细讲解有关怎么解决win8自动断网问题,小编觉得挺实用的,因此分享给大家做个参考,希 香港云主机望大家阅读完这篇文章后可以有所收获。1、首先“开始”菜单,直接选择控制面板,在弹出的“控制面板”窗口,直接点击“网络和共享中心”。2、然后可以在“…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 07/14 17:18
Next 07/14 17:18

相关推荐