java二叉树类_java 二叉树

http://rsrt.javaeye.com/blog/669065

BinaryTree类:

Java代码

package com.javaeye.rsrt;

/**

*

* @author nishiting

*

*/

public class BinaryTree {

private Node root;

/**

* 内部类实现结点类,可提高安全性

* @author nishiting

*

*/

private static class Node {

Node left;

Node right;

int data;

Node(int newData) {

left = null ;

right = null ;

data = newData;

}

}

/**

* 创建一个空的二叉树

*/

public BinaryTree() {

root = null ;

}

/**

* 递归的插入数值

* @param data  要插入的数值

*/

public void insert( int data) {

root = insert(root, data);

}

/**

* 将数值插入到二叉树中,比当前结点小或等于当前结点的插在当前结点的左侧,比当前结点大的数插在当前结点的右侧,每次从根结点开始递归比较

* @param node  当前的结点,就是根结点,只是每次根结点的左右子孙更新

* @param data  要插入的数值

* @return  新排好的二叉树

*/

private Node insert(Node node, int data) {

if (node == null ) {

node = new Node(data);

} else {

if (data <= node.data) {

node.left = insert(node.left, data);

} else {

node.right = insert(node.right, data);

}

}

return (node);

}

/**

* 将数值输入构建二叉树

* @param data  要输入的数值

*/

public void buildTree( int [] data) {

for ( int i = 0 ; i 

insert(data[i]);

}

}

/**

* 递归打印出二叉树

*/

public void printTree() {

printTree(root);

System.out.println();

}

/**

* 从根结点开始遍历,从树的最高层叶子结点开始输出,从左至右

* @param node  当前的结点

*/

private void printTree(Node node) {

if (node == null )

return ;

// left, node itself, right

printTree(node.left);

System.out.print(node.data + "  " );

printTree(node.right);

}

}

package com.javaeye.rsrt;

/**

*

* @author nishiting

*

*/

public class BinaryTree {

private Node root;

/**

* 内部类实现结点类,可提高安全性

* @author nishiting

*

*/

private static class Node {

Node left;

Node right;

int data;

Node(int newData) {

left = null;

right = null;

data = newData;

}

}

/**

* 创建一个空的二叉树

*/

public BinaryTree() {

root = null;

}

/**

* 递归的插入数值

* @param data要插入的数值

*/

public void insert(int data) {

root = insert(root, data);

}

/**

* 将数值插入到二叉树中,比当前结点小或等于当前结点的插在当前结点的左侧,比当前结点大的数插在当前结点的右侧,每次从根结点开始递归比较

* @param node当前的结点,就是根结点,只是每次根结点的左右子孙更新

* @param data要插入的数值

* @return新排好的二叉树

*/

private Node insert(Node node, int data) {

if (node == null) {

node = new Node(data);

} else {

if (data <= node.data) {

node.left = insert(node.left, data);

} else {

node.right = insert(node.right, data);

}

}

return (node);

}

/**

* 将数值输入构建二叉树

* @param data要输入的数值

*/

public void buildTree(int[] data) {

for (int i = 0; i < data.length; i++) {

insert(data[i]);

}

}

/**

* 递归打印出二叉树

*/

public void printTree() {

printTree(root);

System.out.println();

}

/**

* 从根结点开始遍历,从树的最高层叶子结点开始输出,从左至右

* @param node当前的结点

*/

private void printTree(Node node) {

if (node == null)

return;

// left, node itself, right

printTree(node.left);

System.out.print(node.data + " ");

printTree(node.right);

}

}

测试类:

Java代码

package com.javaeye.rsrt;

import junit.framework.TestCase;

public class BinaryTreeTest extends TestCase {

public void testBinaryTreeTest() {

BinaryTree biTree = new BinaryTree();

int [] data = { 2 , 8 , 7 , 4 , 9 , 3 , 1 , 6 , 7 , 5 };

biTree.buildTree(data);

biTree.printTree();

}

}

package com.javaeye.rsrt;

import junit.framework.TestCase;

public class BinaryTreeTest extends TestCase {

public void testBinaryTreeTest() {

BinaryTree biTree = new BinaryTree();

int[] data = { 2, 8, 7, 4 ,9,3,1,6,7,5};

biTree.buildTree(data);

biTree.printTree();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
构建二叉树的算法可以使用递归或迭代的方式实现。 以下是使用递归方式构建二叉树的示例代码: ``` class TreeNode { int val; TreeNode left; TreeNode right; TreeNode(int x) { val = x; } } public class BinaryTree { public TreeNode buildTree(int[] preorder, int[] inorder) { if (preorder == null || inorder == null || preorder.length != inorder.length) { return null; } return buildTreeHelper(preorder, inorder, 0, preorder.length - 1, 0, inorder.length - 1); } private TreeNode buildTreeHelper(int[] preorder, int[] inorder, int preStart, int preEnd, int inStart, int inEnd) { if (preStart > preEnd || inStart > inEnd) { return null; } int rootVal = preorder[preStart]; int rootIndex = 0; for (int i = inStart; i <= inEnd; i++) { if (inorder[i] == rootVal) { rootIndex = i; break; } } int leftSize = rootIndex - inStart; TreeNode root = new TreeNode(rootVal); root.left = buildTreeHelper(preorder, inorder, preStart + 1, preStart + leftSize, inStart, rootIndex - 1); root.right = buildTreeHelper(preorder, inorder, preStart + leftSize + 1, preEnd, rootIndex + 1, inEnd); return root; } } ``` 以上代码中,`buildTree`方法接受两个数组,一个是先序遍历序列,一个是中序遍历序列。通过先序遍历序列的第一个节点确定根节点,在中序遍历序列中找到根节点的位置,根节点左边的节点为左子树,右边的节点为右子树。递归调用`buildTreeHelper`方法建立左右子树,并将其连接到根节点上。 以下是使用迭代方式构建二叉树的示例代码: ``` class TreeNode { int val; TreeNode left; TreeNode right; TreeNode(int x) { val = x; } } public class BinaryTree { public TreeNode buildTree(int[] preorder, int[] inorder) { if (preorder == null || inorder == null || preorder.length != inorder.length) { return null; } Stack<TreeNode> stack = new Stack<>(); TreeNode root = new TreeNode(preorder[0]); stack.push(root); int inorderIndex = 0; for (int i = 1; i < preorder.length; i++) { TreeNode node = stack.peek(); if (node.val != inorder[inorderIndex]) { node.left = new TreeNode(preorder[i]); stack.push(node.left); } else { while (!stack.isEmpty() && stack.peek().val == inorder[inorderIndex]) { node = stack.pop(); inorderIndex++; } node.right = new TreeNode(preorder[i]); stack.push(node.right); } } return root; } } ``` 以上代码中,使用栈来辅助构建二叉树。先将先序遍历序列的第一个节点作为根节点入栈,然后依次遍历先序遍历序列中的每个节点,如果当前节点不等于中序遍历序列中的节点,则表示当前节点是根节点的左子树,将其作为左子节点入栈;否则,不断弹出栈顶元素,直到栈顶元素等于中序遍历序列中的节点,表示当前节点是某个节点的右子树,将其作为右子节点入栈。最终返回根节点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值