zoukankan      html  css  js  c++  java
  • 剑指offer系列16---二叉树的镜像

    【题目】二叉树的镜像
    【思路】方法一:采用递归方式进行交换,先交换根节点的左右节点,接着交换左右结点的左右结点
        方法二:采用非递归方式,即依次遍历左右子树结点依次交换,采用栈操作方式stack

      1 package com.exe4.offer;
      2 import java.util.Stack;
      3 
      4 /**
      5  * 16【题目】二叉树的镜像
      6  *    【思路】方法一:采用递归方式进行交换,先交换根节点的左右节点,接着交换左右结点的左右结点
      7  *             方法二:采用非递归方式,即依次遍历左右子树结点依次交换,采用栈操作方式stack
      8  * @author WGS
      9  *
     10  */
     11 public class TreeMirror {
     12     //二叉树结点定义
     13     public static class TreeNode {
     14         int val = 0;
     15         TreeNode left = null;
     16         TreeNode right = null;
     17 
     18         public TreeNode(int val) {
     19             this.val = val;
     20 
     21         }
     22 
     23     }
     24     //采用递归方式进行交换,先交换根节点的左右节点,接着交换左右结点的左右结点
     25     public void mirrorExchange(TreeNode node){
     26         if(node==null || node.left==null || node.right==null){
     27             return;
     28         }
     29         //开始交换根节点的左右结点
     30         TreeNode tempNode=null;
     31         tempNode=node.left;
     32         node.left=node.right;
     33         node.right=tempNode;
     34         
     35         //继续交换
     36         if(node.left!=null)
     37             mirrorExchange(node.left);
     38         if(node.right!=null)
     39             mirrorExchange(node.right);
     40     }
     41     //采用非递归方式,即依次遍历左右子树结点依次交换,采用栈操作方式s
     42     public void mirrorExchange2(TreeNode root){
     43         if(root==null || root.left==null || root.right==null){
     44             return;
     45         }
     46          Stack<TreeNode> stack = new Stack<TreeNode>();
     47          stack.push(root);
     48          while(!stack.isEmpty()){
     49              TreeNode node=stack.pop();
     50              //交换左右结点
     51              TreeNode temp=node.left;
     52              node.left=node.right;
     53              node.right=temp;
     54              //继续遍历下一个左右结点
     55              if(node.left!=null)
     56                  stack.push(node.left);
     57              if(node.right!=null)
     58                  stack.push(node.right);
     59          }
     60     }
     61 
     62     //前序遍历1
     63     public void preInOreder(TreeNode T){
     64         if(T==null) return;
     65         System.out.println(T.val);
     66         preInOreder(T.left);
     67         preInOreder(T.right);
     68     }
     69      //前序遍历2
     70     public void preOrderTarverse(TreeNode root) {
     71         Stack<TreeNode> s = new Stack<TreeNode>();
     72         while (root != null || !s.isEmpty()) {
     73             //遍历左子树
     74             while (root != null) {
     75                 System.out.println(root.val);
     76                 s.push(root);
     77                 root = root.left;
     78             }
     79             // 左子树遍历结束,继续遍历右子树
     80             if (!s.isEmpty()) {
     81                 root = s.pop();
     82                 root = root.right;
     83             }
     84         }
     85     }
     86 
     87     public static void main(String[] args) {
     88         TreeNode root = new TreeNode(8);
     89         TreeNode node1 = new TreeNode(6);
     90         TreeNode node2 = new TreeNode(10);
     91         TreeNode node3 = new TreeNode(5);
     92         TreeNode node4 = new TreeNode(7);
     93         TreeNode node5 = new TreeNode(9);
     94         TreeNode node6 = new TreeNode(11);
     95 
     96         root.left = node1;
     97         root.right = node2;
     98         node1.left = node3;
     99         node1.right = node4;
    100         node2.left = node5;
    101         node2.right = node6;
    102 
    103         TreeMirror r = new TreeMirror();
    104         r.mirrorExchange2(root);
    105 
    106         r.preOrderTarverse(root);
    107     }
    108 }
  • 相关阅读:
    阿里云物联网平台: 使用阿里云物联网平台提供的自定义Topic通信控制(Air202,TCP透传指令)
    ESA2GJK1DH1K基础篇: 源码使用注意事项和程序优化
    ESP8266 SDK开发: 常见问题及程序BUG修复
    ESP8266 SDK开发: 微信小程序篇-微信小程序通过UDP实现和ESP8266局域网通信控制
    ESP8266 SDK开发: 物联网篇-ESP8266连接阿里云物联网平台,使用阿里云提供的物模型Topic通信控制
    ESP8266 SDK开发: 物联网篇-ESP8266连接阿里云物联网平台,使用阿里云提供的自定义Topic通信控制
    ESA2GJK1DH1K基础篇: APP使用SmartConfig绑定Wi-Fi 设备并通过MQTT控制设备(V1.0)(AT+TCP非透传指令)
    【spring源码分析】@Value注解原理
    【vue】npm、node版本查看及npm常用命令
    【vue】常用操作
  • 原文地址:https://www.cnblogs.com/noaman/p/5430395.html
Copyright © 2011-2022 走看看