当前位置: 首页 > news >正文

java-数据结构-前中后序遍历

文章目录

  • java-数据结构-前中后序遍历
    • 遍历说明
    • 节点的定义
    • 二叉树定义
      • 前序遍历
      • 中序遍历
      • 后序遍历
    • 前序遍历打印
    • 中序遍历打印
    • 后序遍历打印
    • 测试
      • 代码
      • 二叉树图形结构
      • 运行结果

java-数据结构-前中后序遍历

遍历说明

前序遍历:根-左-右
中序遍历:左-根-右
后序遍历:左-右-根

节点的定义

//先创建HeroNode 结点
class HeroNode {
	private int no;
	private String name;
	private HeroNode left; //默认null
	private HeroNode right; //默认null
	public HeroNode(int no, String name) {
		this.no = no;
		this.name = name;
	}
        //setter,getter省略

	public String toString() {
		return "HeroNode [no=" + no + ", name=" + name + "]";
	}
	
	//前序遍历
	//中序遍历
	//后序遍历
}

二叉树定义

//定义BinaryTree 二叉树
class BinaryTree {
	private HeroNode root;
	public void setRoot(HeroNode root) {
		this.root = root;
	}	
	//前序遍历-打印
	//中序遍历-打印
	//后序遍历-打印
}

前序遍历

在这里插入图片描述

	//前序遍历
	public void preOrder() {
		System.out.println(this); //先输出父结点
		//递归向左子树前序遍历
		if(this.left != null) {
			this.left.preOrder();
		}
		//递归向右子树前序遍历
		if(this.right != null) {
			this.right.preOrder();
		}
	}

中序遍历

在这里插入图片描述

	//中序遍历
	public void infixOrder() {
		
		//递归向左子树中序遍历
		if(this.left != null) {
			this.left.infixOrder();
		}
		//输出父结点
		System.out.println(this);
		//递归向右子树中序遍历
		if(this.right != null) {
			this.right.infixOrder();
		}
	}

后序遍历

在这里插入图片描述

	//后序遍历
	public void postOrder() {
		if(this.left != null) {
			this.left.postOrder();
		}
		if(this.right != null) {
			this.right.postOrder();
		}
		System.out.println(this);
	}

前序遍历打印

	//前序遍历-打印
	public void preOrder() {
		if(this.root != null) {
			this.root.preOrder();
		}else {
			System.out.println("二叉树为空,无法遍历");
		}
	}

中序遍历打印

	//中序遍历-打印
	public void infixOrder() {
		if(this.root != null) {
			this.root.infixOrder();
		}else {
			System.out.println("二叉树为空,无法遍历");
		}
	}

后序遍历打印

	//后序遍历-打印
	public void postOrder() {
		if(this.root != null) {
			this.root.postOrder();
		}else {
			System.out.println("二叉树为空,无法遍历");
		}
	}

测试

运行测试用例,打印运行结果。

代码

	public static void main(String[] args) {
		//先需要创建一颗二叉树
		BinaryTree binaryTree = new BinaryTree();
		//创建需要的结点
		HeroNode root = new HeroNode(1, "宋江");
		HeroNode node2 = new HeroNode(2, "吴用");
		HeroNode node3 = new HeroNode(3, "卢俊义");
		HeroNode node4 = new HeroNode(4, "林冲");
		HeroNode node5 = new HeroNode(5, "关胜");
		
		//说明,我们先手动创建该二叉树,后面我们学习递归的方式创建二叉树
		root.setLeft(node2);
		root.setRight(node3);
		node3.setRight(node4);
		node3.setLeft(node5);
		binaryTree.setRoot(root);
		
		//测试
		System.out.println("前序遍历"); // 1,2,3,5,4
		binaryTree.preOrder();
		
		//测试 
		System.out.println("中序遍历");
		binaryTree.infixOrder(); // 2,1,5,3,4
		
		System.out.println("后序遍历");
		binaryTree.postOrder(); // 2,5,4,3,1
		}

二叉树图形结构

因为csdn 不支持dot语言,so,这里用表格来显示树

hero 1:宋江
hero 2:吴用hero 3:卢俊
hero 5:关胜hero 4:林冲

如图
在这里插入图片描述

前序遍历:根-左-右 
中序遍历:左-根-右 
后序遍历:左-右-根 

运行结果

前序遍历
HeroNode [no=1, name=宋江]
HeroNode [no=2, name=吴用]
HeroNode [no=3, name=卢俊义]
HeroNode [no=5, name=关胜]
HeroNode [no=4, name=林冲]
中序遍历
HeroNode [no=2, name=吴用]
HeroNode [no=1, name=宋江]
HeroNode [no=5, name=关胜]
HeroNode [no=3, name=卢俊义]
HeroNode [no=4, name=林冲]
后序遍历
HeroNode [no=2, name=吴用]
HeroNode [no=5, name=关胜]
HeroNode [no=4, name=林冲]
HeroNode [no=3, name=卢俊义]
HeroNode [no=1, name=宋江]

参考资料

相关文章:

  • java-数据结构-前中后序查找
  • java-数据结构-顺序存储二叉树
  • java-数据结构-线索化二叉树
  • java-数据结构-大顶堆和小顶堆
  • java-数据结构-赫夫曼树(Huffman Tree)
  • java-数据结构-哈夫曼编码(Huffman Coding)
  • java批量修改文件名工具类
  • deepin安装后wps提示缺少字体
  • Unknown initial character set index '45' received from server
  • 阿里云maven公共代理库
  • deepin安装anaconda后,创建图标
  • 论一只爬虫的自我修养——python使用代理
  • Android Studio打开工具栏
  • Android Studio入门小例子
  • 如何证明素数个数无限个
  • 【前端学习】-粗谈选择器
  • Essential Studio for ASP.NET Web Forms 2017 v2,新增自定义树形网格工具栏
  • exports和module.exports
  • Flannel解读
  • Koa2 之文件上传下载
  • nodejs调试方法
  • 和 || 运算
  • 欢迎参加第二届中国游戏开发者大会
  • 机器学习 vs. 深度学习
  • 如何解决微信端直接跳WAP端
  • 使用阿里云发布分布式网站,开发时候应该注意什么?
  • 终端用户监控:真实用户监控还是模拟监控?
  • %3cli%3e连接html页面,html+canvas实现屏幕截取
  • (20)目标检测算法之YOLOv5计算预选框、详解anchor计算
  • (4)事件处理——(7)简单事件(Simple events)
  • (二)WCF的Binding模型
  • (转) RFS+AutoItLibrary测试web对话框
  • (转)Google的Objective-C编码规范
  • (转)linux下的时间函数使用
  • (转载)Google Chrome调试JS
  • .[hudsonL@cock.li].mkp勒索加密数据库完美恢复---惜分飞
  • .cfg\.dat\.mak(持续补充)
  • .NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
  • .net core MVC 通过 Filters 过滤器拦截请求及响应内容
  • .net core 连接数据库,通过数据库生成Modell
  • .NET CORE使用Redis分布式锁续命(续期)问题
  • .NET 反射 Reflect
  • .net 重复调用webservice_Java RMI 远程调用详解,优劣势说明
  • .NET和.COM和.CN域名区别
  • .NET面试题(二)
  • .project文件
  • @JsonSerialize注解的使用
  • [ MSF使用实例 ] 利用永恒之蓝(MS17-010)漏洞导致windows靶机蓝屏并获取靶机权限
  • [Android开源]EasySharedPreferences:优雅的进行SharedPreferences数据存储操作
  • [AutoSar]BSW_Com07 CAN报文接收流程的函数调用
  • [C++参考]拷贝构造函数的参数必须是引用类型
  • [CF482B]Interesting Array
  • [corCTF 2022] CoRJail: From Null Byte Overflow To Docker Escape
  • [Gamma]阶段测试报告
  • [React源码解析] Fiber (二)