在JAVA中实现二叉树结构
来源:互联网 发布:template.js教程 编辑:程序博客网 时间:2024/05/19 22:00
*
* 讲解:
* 二个方法函数,一个寻找关键字--searchkey 另一个是插入一个结点:insertTree
* 另外这是一个完全的先序遍历二叉树的语法。先根结点,再左结点,如无再右结点,
* 如此递归至搜索完毕。
*
*/
private BinaryTree root = null;
public BinaryTreeTest() {
init();
}
private void init() {
int data[] = {12, 11, 34, 45, 67, 38, 56, 43, 22, 8 };
root = new BinaryTree(data[0]);
System.out.println("二叉树的中的数据结构:");
System.out.println("------------------------------------");
System.out.println(data[0] + ":root");
for (int i = 1; i < data.length; i++) {
System.out.print(data[i] + ":");
root.insertTree(root, data[i]);
}
System.out.println("------------------------------------");
}
public void serach(int key) {
if (searchkey(root, key)) {
System.out.println("找到了:" + key);
} else {
System.out.println("没有找到:" + key);
}
}
private boolean searchkey(BinaryTree root, int key) {
if (root == null) {
return false;
} else if (root.data == key) {
return true;
} else if (key >= root.data) {
return searchkey(root.rightpoiter, key);
}
return searchkey(root.leftpoiter, key);
}
class BinaryTree {
int data;
BinaryTree leftpoiter;
BinaryTree rightpoiter;
BinaryTree(int data) {
this.data = data;
leftpoiter = null;
rightpoiter = null;
}
private void insertTree(BinaryTree root, int data) {
if (data >= root.data) {
if (root.rightpoiter == null) {
System.out.println(" -> new rightpoiter");
root.rightpoiter = new BinaryTree(data);
} else {
System.out.print(" -> rightpoiter");
insertTree(root.rightpoiter, data);
}
} else {
if (root.leftpoiter == null) {
System.out.println(" -> new leftpoiter");
root.leftpoiter = new BinaryTree(data);
} else {
System.out.print(" -> leftpoiter");
insertTree(root.leftpoiter, data);
}
}
}
}
public static void main(String args[]) {
BinaryTreeTest b = new BinaryTreeTest();
int key = 8; //key:任意数值
b.serach(key); //到二叉树中查找
}
}
运行结果:
C:\java>java BinaryTreeTest
二叉树的中的数据结构:
------------------------------------
12:root
11: -> new leftpoiter
34: -> new rightpoiter
45: -> rightpoiter -> newrightpoiter
67: -> rightpoiter ->rightpoiter -> new rightpoiter
38: -> rightpoiter ->rightpoiter -> new leftpoiter
56: -> rightpoiter ->rightpoiter -> rightpoiter -> newleftpoiter
43: -> rightpoiter ->rightpoiter -> leftpoiter -> newrightpoiter
22: -> rightpoiter -> newleftpoiter
8: -> leftpoiter -> newleftpoiter
找到了:8
- 在JAVA中实现二叉树结构
- 在JAVA中实现二叉树结构
- 转: 在JAVA中实现的二叉树结构
- JAVA实现二叉树结构
- 二叉树结构的java实现
- JAVA中实现二叉树
- JAVA中二叉树实现
- 树和二叉树在java中
- 二叉树的基本结构以及java实现
- java 实现二叉树结构的基本运算详细代码
- 链式结构实现二叉树
- 二叉树顺序结构实现
- 二叉树链式结构实现
- 二叉树顺序结构实现
- 二叉树结构的实现
- 中序线索二叉树Java实现
- java中简单二叉树的实现
- 在二叉树中找出和为某一值的所有路径-java实现
- http://api.java2000.net/
- java正则表达式
- java 排序
- 网页知识大全(1)
- 网页知识大全(2)
- 在JAVA中实现二叉树结构
- Java-Properties类的使用
- Java日期选择控件
- j2ee笔试题目
- java基础
- ASCII是字母 而汉字是Unicode
- 经典题
- 面试题(1)
- UML建模-如何使用用例获取需求