Java二叉树介绍:数据结构、创建、遍历

本文介绍了一种使用先序列表创建二叉树的方法,并提供了先序、中序及后序三种遍历方式的递归实现。通过这些方法可以有效地理解和操作二叉树结构。

 


/*
 * 二叉树数据结构
 * 
 */

 

 

class TreeNode<T>
{
    public T data;
    public TreeNode<T> left;
    public TreeNode<T> right;
    public TreeNode(T data, TreeNode<T> left, TreeNode<T> right)
    {
        this.data = data;
        this.left = left;
        this.right = right;
    }
}


/*
 * 先序创建二叉树
 * 返回:根节点
 */
public TreeNode<T>  creatBinaryPre(LinkedList<T> treeData)
{
	TreeNode<T> root=null;
	T data=treeData.removeFirst();
	if (data!=null) 
	{
		root=new TreeNode<T>(data, null, null);
		root.left=creatBinaryPre(treeData);
		root.right=creatBinaryPre(treeData);
	}
	return root;
}


/*
 * 先序遍历二叉树(递归)
 */
public void PrintBinaryTreePreRecur(TreeNode<T> root)
{
	if (root!=null) 
	{
		System.out.print(root.data);
		PrintBinaryTreePreRecur(root.left);
		PrintBinaryTreePreRecur(root.right);
	}
}
/*
 * 中序遍历二叉树(递归)
 */
public void PrintBinaryTreeMidRecur(TreeNode<T> root)
{
	if (root!=null) 
	{
		PrintBinaryTreeMidRecur(root.left);
		System.out.print(root.data);
		PrintBinaryTreeMidRecur(root.right);
	}
}
/*
 * 后序遍历二叉树(递归)
 */
public void PrintBinaryTreeBacRecur(TreeNode<T> root)
{
	if (root!=null) 
	{
		PrintBinaryTreeBacRecur(root.left);
		PrintBinaryTreeBacRecur(root.right);
		System.out.print(root.data);
	}
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值