镜像二叉树——剑指Offer
https://www.nowcoder.net/practice/564f4c26aa584921bc75623e48ca3011?tpId=13&tqId=11171&tPage=1&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking
题目描述
思路:
代码:
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};*/
class Solution {
void switchChild(TreeNode *pNode) {
if (pNode == NULL) return;
TreeNode *tmp = pNode->left;
pNode->left = pNode->right;
pNode->right = tmp;
}
public:
void Mirror(TreeNode *pRoot) {
// non recursive, any iterate, and change child
stack<TreeNode *> stk; if (pRoot == NULL) return;
stk.push(pRoot); while (!stk.empty()) {
TreeNode *tmp = stk.top();
stk.pop();
switchChild(tmp);
if (tmp->left) stk.push(tmp->left);
if (tmp->right) stk.push(tmp->right);
} } void Mirror2(TreeNode *pRoot) {
// recursive
if (pRoot == NULL) return;
Mirror(pRoot->left);
Mirror(pRoot->right);
TreeNode *tmp = pRoot->left;
pRoot->left = pRoot->right;
pRoot->right = tmp;
}
};
结果:
一模一样快。可能因为非递归实现的也是先序,用了栈,其实和递归程序的逻辑是一样的。
非递归:

递归:

镜像二叉树——剑指Offer的更多相关文章
- 4、重建二叉树------------>剑指offer系列
		
题目1-二叉树重建 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字. 例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序 ...
 - 面试题目——《剑指Offer》
		
1.把一个字符串转换成整数——<剑指Offer>P29 2.求链表中的倒数第k个结点——<剑指Offer>P30 3.实现Singleton模式——<剑指Offer> ...
 - 《剑指offer》题解
		
有段时间准备找工作,囫囵吞枣地做了<剑指offer>提供的编程习题,下面是题解收集. 当初没写目录真是个坏习惯(-_-)||,自己写的东西都要到处找. 提交的源码可以在此repo中找到:h ...
 - 【剑指Offer】剑指offer题目汇总
		
本文为<剑指Offer>刷题笔记的总结篇,花了两个多月的时间,将牛客网上<剑指Offer>的66道题刷了一遍,以博客的形式整理了一遍,这66道题属于相对基础的算法题目,对于 ...
 - 《剑指offer》 二叉树的镜像
		
本题来自<剑指offer>二叉树的镜像 题目: 操作给定的二叉树,将其变换为源二叉树的镜像. 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 ...
 - 【Java】 剑指offer(27) 二叉树的镜像
		
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 请完成一个函数,输入一个二叉树,该函数输出它的镜像. 思路 画图可 ...
 - 《剑指offer》二叉树镜像
		
剑指offer简单题,但是能一下写对也需要小心考虑细节. 题目描述 操作给定的二叉树,将其变换为源二叉树的镜像. 输入描述: 二叉树的镜像定义:源二叉树 8 / 6 10 / / 5 7 9 11 ...
 - 剑指Offer - 九度1521 - 二叉树的镜像
		
剑指Offer - 九度1521 - 二叉树的镜像2013-11-30 23:32 题目描述: 输入一个二叉树,输出其镜像. 输入: 输入可能包含多个测试样例,输入以EOF结束.对于每个测试案例,输入 ...
 - 剑指Offer(十八):二叉树的镜像
		
剑指Offer(十八):二叉树的镜像 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net/baidu ...
 
随机推荐
- 修改vim注释字体颜色
			
vim /etc/vimrc#最后一行新增代码块hi comment ctermfg=6 注:注释用 " 标注 PS:默认的注释颜色是4 然后有0,1,2,3,4,5,6,7来选择.可以除 ...
 - PHP会话控制考察点
			
为什么要使用会话控制技术 HTTP协议是无状态的,也就是说HTTP没有一个内建的机制来维护两个事务之间的状态.当一个用户完成一个请求发起第二个请求的时候,服务器无法知道这次请求是来自于上一次的客户.而 ...
 - wifi钓鱼之--Pumpkin
			
无线钓鱼 前言:请准备一块rt3070的外接网卡 Pumpkin是一款无线安全检测工具WiFi-Pumpkin的使用,利用该工具可以伪造接入点完成中间人攻击,同时也支持一些其它的无线渗透功能.旨在 ...
 - webstorm 设置ES6语法支持以及添加vuejs开发配置
			
参考文章:https://blog.csdn.net/diligentkong/article/details/75040651
 - 字符集匹配:\s 匹配一个空格,一边后面加量词表示多个空格,\s*表示0个以上空格,\s+表示1个以上空格,\s相当于[\f\r\n\t ]5种空白字符。
			
字符集匹配:\s 匹配一个空格,一边后面加量词表示多个空格,\s*表示0个以上空格,\s+表示1个以上空格,\s相当于[\f\r\n\t ]5种空白字符.
 - bootstrap-table的一些基本使用及表内编辑的实现
			
最近工作需要接触了bootstrap-table 所以研究了一下,并做了笔记,红色位置要特别注意 前端主要使用了 jquery bootstrap-table bootstrap-edittable ...
 - P1759 通天之潜水(不详细,勿看)(动态规划递推,组合背包,洛谷)
			
题目链接:点击进入 题目分析: 简单的组合背包模板题,但是递推的同时要刷新这种情况使用了哪些物品 ac代码: #include<bits/stdc++.h> using namespace ...
 - 全国高校绿色计算大赛 预赛第一阶段(Python)
			
第1关将字符串反转 #!/usr/bin/env python # -*- coding: utf-8 -*- class Task: def inversion(self, str): # **** ...
 - 大项目之网上书城(八)——数据库大改&添加图书
			
目录 大项目之网上书城(八)--数据库大改&添加图书 主要改动 1.数据库新增表 代码 2.数据库新增触发器 3.其他对BookService和BookDao的修改 代码 4.addBook. ...
 - HYSBZ - 2763 飞行路线(分层图最短路线)
			
题目: Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为0到n-1,一共有m种航线,每种航线连接两个城市,并且航线有一定的价 ...