给定一个二叉树

struct TreeLinkNode { TreeLinkNode *left; TreeLinkNode *right; TreeLinkNode *next; }

填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL。

初始状态下,所有 next 指针都被设置为 NULL。

说明:

  • 你只能使用额外常数空间。
  • 使用递归解题也符合要求,本题中递归程序占用的栈空间不算做额外的空间复杂度。
  • 你可以假设它是一个完美二叉树(即所有叶子节点都在同一层,每个父节点都有两个子节点)。

示例:

给定完美二叉树,

1 / \ 2 3 / \ / \ 4 5 6 7

调用你的函数后,该完美二叉树变为:

1 -> NULL / \ 2 -> 3 -> NULL / \ / \ 4->5->6->7 -> NULL

class Solution {
public:
void connect(TreeLinkNode *root)
{
if(root == NULL)
return;
queue<TreeLinkNode*> q;
q.push(root);
while(!q.empty())
{
int len = q.size();
for(int i = 0; i < len; i++)
{
TreeLinkNode *node = q.front();
q.pop();
node ->next = i == len - 1? NULL : q.front();
if(node ->left)
q.push(node ->left);
if(node ->right)
q.push(node ->right);
}
}
}
};

最新文章

  1. 红帽RHEL7版本RHCE认证学习及考试经历
  2. 浅谈javascript中事件冒泡与事件捕获
  3. matlab global 不能传向量/矩阵
  4. HDU 1878 欧拉回路
  5. 第二课:判断js变量的类型以及domReady的原理
  6. firebug console使用
  7. ecshop的smarty库还原成smarty原生库方法
  8. 一天一个mysql函数(二) FIND_IN_SET()
  9. Android:反编译查看源码
  10. Jdbc 事务
  11. java集合--Queue用法
  12. Linux五种IO模型性能分析
  13. sqlserver isnull判断
  14. (三十一)PickerView自定义视图
  15. laravel+Redis简单实现队列通过压力测试的高并发处理
  16. Senparc.Weixin.TenPay 正式发布
  17. 关于Select2下拉框组件
  18. 移除input框type=&quot;number&quot;在部分浏览器的默认上下按钮
  19. swift的异常处理:本质是错误信息的传递方式
  20. linux split 切割大文件

热门文章

  1. c# Data = select new{} 返回值的显示
  2. java笔试之放苹果
  3. easyui treegrid的使用示例
  4. T3118 01完美矩阵【计数,前缀和,差分,好题】
  5. Python-线程(3)-协程
  6. Django常用组件之分页器
  7. Android开发随笔
  8. 左神算法进阶班8_1数组中累加和小于等于aim的最长子数组
  9. 群晖系统下btfs(占用5%)和ext4文件格式的硬盘占用和选择
  10. 《DSP using MATLAB》Problem 8.28