二叉树的存储
二叉树主要是用二叉链表来存储,二叉链表有一个数据域data和两个指针域lchild、rchild构成,分别存放左孩子和右孩子的指针。二叉链表的结点结构定义如下:
class BiTNode {
int data; // 数据域
BiTNode left; // 左孩子指针
BiTNode right; // 右孩子指针
}
二叉树的创建
这里用整型数组来代表二叉树的结点,如arr=[1,2,4,0,0,5,0,0,3,6,0,0,0],这里的顺序是按照二叉树的前序遍历结果顺序存储,构建的二叉树如下图所示。这里的0表示空结点。
下面来具体实现二叉树的建立过程:
public class TestBiTree {
static int count = 0; //定义计数变量
/*通过数组来构建二叉树,二叉链表*/
public BiTNode createBiTree(BiTNode root, int[] arr, int i){
if(i<arr.length){
if(arr[i] == 0)
root = null;
else{
BiTNode left = new BiTNode();
BiTNode right = new BiTNode();
root.data = arr[i];
root.left = createBiTree(left, arr, ++count);
root.right = createBiTree(right, arr, ++count);
}
}
return root;
}
// 返回二叉树的深度
public int TreeDepth(BiTNode root){
if(root == null) return 0;
int leftDepth <