数据结构之JAVA中的树

为什么需要树这种数据结构

1)数组储方式的
优点:通过下标方式访问元素,速度快。对于有序数组,还可使用二分查找提高检索速度。
缺点果要检索具体某个值,或者插入值(按一定顺序)会整体移动,效率较低 [示意图]

2)式存储方式的分析
优点:在一定程度上对数组存储方式有优化(比如:插入一个数节点,只需要将入节点,链接到链表中即可, 删除效率也很好)
点:在进行检索时,效率仍然较低,比如(检索某个值,需要从头节点开始遍历) 示意图

3)存储方式的分析
能提高数据存储,读取的效率如利用 二叉排序树(Binary Sort Tree),既可以保证数据的检索速度,同时也可以保证数据的插入,删除,修改的速度

 

创建树并手动测试前中后序遍历

package tree;

public class BinaryTreeDemo {

	public static void main(String[] args) {
		// 先需要创建一颗二叉树
		BinaryTree bt = new BinaryTree();
		// 创建需要的结点
		HeroNode root = new HeroNode(1, "唐僧");
		HeroNode node2 = new HeroNode(2, "孙悟空");
		HeroNode node3 = new HeroNode(3, "猪八戒");
		HeroNode node4 = new HeroNode(4, "沙和尚");
		
		//手动方式创建二叉树
		bt.setRoot(root);
		root.setLeft(node2);
		root.setRight(node3);
		node3.setRight(node4);
		// 前序遍历
		System.out.println("前序遍历");
		bt.preOrder();
		// 中序遍历
		System.out.println("中序遍历");
		bt.infixOrder();
		// 后序遍历
		System.out.println("后序遍历");
		bt.postOrder();
	}
}

// 定义BinaryTree二叉树
class BinaryTree {
	private HeroNode root;

	public void setRoot(HeroNode root) {
		this.root = root;
	}

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

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

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

// 先创建HeroNode结点
class HeroNode {
	private int no;// 编号
	private String name;// 名字
	private HeroNode left;
	private HeroNode right;

	public int getNo() {
		return no;
	}

	public void setNo(int no) {
		this.no = no;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public HeroNode getLeft() {
		return left;
	}

	public void setLeft(HeroNode left) {
		this.left = left;
	}

	public HeroNode getRight() {
		return right;
	}

	public void setRight(HeroNode right) {
		this.right = right;
	}

	public HeroNode(int no, String name) {
		super();
		this.no = no;
		this.name = name;
	}

	

	@Override
	public String toString() {
		return "HeroNode [no=" + no + ", name=" + name + "]";
	}

	// 编写前序遍历的方法
	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.preOrder();
		}
		// 输出父节点
		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);
	}
}

结果如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值