给定一颗完全二叉树,给每一层添加上next的指针,从左边指向右边
给你机会发出声音,但是不给你机会证明高层的决定是错的
RT: 时间复杂度O(n) 空间复杂度O(1)

void Solution::yahooTree(TreeNode *root)
{
if (root == NULL)
return;
TreeNode *p = root;
root->next = NULL;
TreeNode *tmp = root->left;
while(p){
if (p->right!=NULL){
if (p->next!=NULL){
p->right->next = NULL;
p->left->next = p->right;
}else{
p->right->next = p->next->left;
p->left->next = p->right;
}
}else if (p->left!=NULL){
p->left->right = NULL;
}
p = p->next;
if (p == NULL){
if (tmp!=NULL)){
p = tmp;
tmp = tmp->left;
}else{
return ;
}
}
}
}

给定一颗完全二叉树,给每一层添加上next的指针,从左边指向右边的更多相关文章
- 对于一颗完全二叉树,要求给所有节点加上一个pNext指针,指向同一层的相邻节点-----层序遍历的应用题
		题目:对于一颗完全二叉树,要求给所有节点加上一个pNext指针,指向同一层的相邻节点:如果当前节点已经是该层的最后一个节点,则将pNext指针指向NULL:给出程序实现,并分析时间复杂度和空间复杂度. ... 
- <数据结构>XDOJ317.输出完全二叉树的某一层
		问题与解答 问题描述 对一棵完全二叉树,输出某一深度的所有节点,有则输出这些节点,无则输出EMPTY. 输入格式 输入有多组数据. 每组数据第一行输入一个结点数n(1<=n<=1000), ... 
- 简析TCP的三次握手与四次分手(TCP协议头部的格式,数据从应用层发下来,会在每一层都会加上头部信息,进行封装,然后再发送到数据接收端)good
		2014-10-30 分类:理论基础 / 网络开发 阅读(4127) 评论(29) TCP是什么? 具体的关于TCP是什么,我不打算详细的说了:当你看到这篇文章时,我想你也知道TCP的概念了,想要更 ... 
- mysql添加上log_bin步骤如下
		mysql添加上log_bin步骤如下 
- 给定一颗二叉搜索树,请找出其中的第k小的结点。例如, 5 / \ 3 7 /\ /\ 2 4 6 8 中,按结点数值大小顺序第三个结点的值为4。
		// ConsoleApplication2.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include "stdafx.h ... 
- 给定一颗二叉搜索树,请找出其中的第k大的结点。例如, 5 / \ 3 7 /\ /\ 2 4 6 8 中,按结点数值大小顺序第三个结点的值为4。
		/* struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x ... 
- IIS6.0添加上.net4.0后,以前的.net系统出现“服务器应用程序不可用”的错误提示解决办法
		把VS2010开发的网站.net4.0部署到Windows Server 2003的服务器上去, Windows Server 2003操作系统自带的为IIS 6.0,IIS 6.0一般只支持.NET ... 
- cocopod 中添加第三方框架,包含静态库文件,使用svn添加上传
		step one: 进入静态库文件的目录 cd 路径: step two:使用命令添加 svn add 静态库名字; 然后更新一下代码就OK 
- SSH上一个随笔的基础上添加上hibernate支持
		配置文件 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.o ... 
随机推荐
- linux 源代码目录结构
			Linux源代码目录树结构 (2008-04-21 09:14) 分类: Linux/Unix Linux用来支持各种体系结构的源代码包含大约4500个C语言程序,存放在270个左右的子目录下,总共大 ... 
- HDU5032 Always Cook Mushroom(树状数组&&离线)
			树状数组+询问离线.一个优化是需要的,就是先对1000*1000个点先排序,而不是每次都生成这1000*1000个点然后和询问一起排序,那样会tle. #include <iostream> ... 
- Jquery操作层级选择器
			<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ... 
- 判断scrollView的滑动方向
			第一种方式: float lastContentOffset; - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView { las ... 
- my.ini配置详解
			Mysql my.ini 配置文件详解 #BEGIN CONFIG INFO #DESCR: 4GB RAM, 只使用InnoDB, ACID, 少量的连接, 队列负载大 #TYPE: SYSTEM ... 
- 任意选若干个不相邻的数得到的和最大【dp】
			非相邻数最大和 ///*任意选若干个不相邻的数得到的和最大*/ #include<cstdio> #include<cstring> #include<queue> ... 
- Codeforces 631B  Print Check (思维)
			题目链接 Print Check 注意到行数加列数最大值只有几千,那么有效的操作数只有几千,那么把这些有效的操作求出来依次模拟就可以了. #include <bits/stdc++.h> ... 
- MyBatis一级缓存(转载)
			<深入理解mybatis原理> MyBatis的一级缓存实现详解 及使用注意事项 http://demo.netfoucs.com/luanlouis/article/details/41 ... 
- 转:一个经典例子让你彻彻底底理解java回调机制
			一个经典例子让你彻彻底底理解java回调机制 转帖请注明本文出自xiaanming的博客(http://blog.csdn.net/xiaanming/article/details/17483273 ... 
- SQLServer出现不允许保存更改的问题解决
			如图所示: 解决方法: [工具]->[选项] 
