栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

二叉树排序-Java版本

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

二叉树排序-Java版本

利用二叉树结构以及遍历方式可以实现基于二叉树的元素排序处理。

首先根据插入元素的大小与根节点大小的比较来构建一颗完整的树。

 

在构建好二叉树之后,并没有继续排序,所以我们需要使用一个中序遍历,因为中序遍历的顺序是左-根-右

5-8-9-11-12-20,神奇吧,我也觉得是!至于为什么呢?数学原理回头再说吧!

public class BinaryTreeSort {
	
	class Node{
		private E item; //存放元素
		private Node left; // 存放左子树地址
		private Node right; //存放右子树地址
		//添加构造方法
		Node(E item){
			this.item =item;
		}
		
		public void addNode(Node node) {
			//完成新结点中的元素与当前结点中的元素判断
			//如果新结点中的元素小于当前节点中的元素,那么新结点则放到当前结点的左子树中
			if(node.item.intValue() node = new Node<>(element);
		//判断当前二叉树中是否有根节点,如果没有,那么新节点则为根节点
		if(this.root == null) {
			this.root = node;
		}else {
			this.root.addNode(node);
		}
		
	}

	
	public void sort() {
		//判断根节点是否为空
		if(this.root == null) {
			return;
		}else {
			this.root.inorderTraversal();
		}
	}
	public static void main(String[] args) {
		BinaryTreeSort tree = new BinaryTreeSort<>();
		//1,8,6,3,5,2
		tree.add(1);
		tree.add(8);
		tree.add(6);
		tree.add(3);
		tree.add(5);
		tree.add(2);
		tree.sort();
	}
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/631379.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号