资源简介
本代码由java语言实现二叉树的各种操作
包括树的创建,查找,删除,按层遍历,输出所有路径,中序遍历等操作

代码片段和文件信息
//本代码包括树的创建,查找,删除,按层遍历,输出所有路径,中序遍历等操作
package com.xie.src;
class node{
int number;
node left;
node right;
}
class tree{
public node rootnode;
tree(){
rootnode = null;
}
void insert(node in){//插入
node temp = rootnode;
if(rootnode == null){
rootnode = in;
return;
}
while(temp != null){
if(in.number == temp.number){
break;
}else if(in.number > temp.number){
if(temp.right == null){
temp.right = in;
break;
}else{
temp = temp.right;
}
}else{
if(temp.left == null){
temp.left = in;
break;
}else{
temp = temp.left;
}
}
}
}
node find(int num){//查找
node temp = rootnode;
while(temp != null){
if(temp.number == num){
break;
}else if(num > temp.number){
temp = temp.right;
}else{
temp = temp.left;
}
}
return temp;
}
void copy(node dest node src){
if(dest != null && src != null){
dest.number = src.number;
}
}
void findbylayer(){ //按层遍历
int front rear;
node[] na;
node temp= rootnode;
na = new node[100];
front = rear = 0;
while(temp != null){
if(rear == 0){
na[front] = rootnode;
rear++;
}else{
temp = na[++front];
}
if(front >= rear || temp == null){
break;
}
System.out.println(“ “ + temp.number + “ index = “ + front);
if(temp.left != null){
na[rear++] = temp.left;
}
if(temp.right != null){
na[rear++] = temp.right;
}
}
for(int i = 0; i < front; i++){
System.out.print(“ “ + na[i].number);
}
System.out.println();
}
void delete(node in){//删除
node parent = null;
node child = rootnode;
node temp;
boolean leftside = true;
if(child == null){
return;
}
while(child != null){
if(child.number == in.number){
break;
}else if(child.number > in.number){
parent = child;
child = child.left;
leftside = true;
}else{
parent = child;
child = child.right;
leftside = false;
}
}
if(child == null){
System.out.println(“Cannot find the num “ + in.number);
return;
}
if(child.number == rootnode.number){
if(rootnode.left == null && rootnode.right == null){
rootnode = null;
}
if(rootnode.left != null && rootnode.right == null){
rootnode = rootnode.left;
return;
}else if(rootnode.left == null && rootnode.right != null){
rootnode = rootnode.right;
return;
}
}
if(child.left == null && child.right == null){//叶子节点
if(leftside){
parent.left = null;
}else{
parent.right = null;
}
}else if(child.left != null && child.right == null){
if(leftside){
parent.left = child.left;
}else{
parent.right = child.left;
}
}else if(child.right != null && child.left == null){
if(leftside){
parent.left = child.right;
}else{
p
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 0 2011-07-19 13:51 myjavatest\
文件 295 2011-07-19 13:50 myjavatest\.classpath
文件 386 2011-07-19 13:50 myjavatest\.project
目录 0 2011-07-19 13:50 myjavatest\.settings\
文件 629 2011-07-19 13:50 myjavatest\.settings\org.eclipse.jdt.core.prefs
目录 0 2011-07-19 13:51 myjavatest\com\
目录 0 2011-07-19 13:51 myjavatest\com\xie\
目录 0 2011-10-11 15:07 myjavatest\com\xie\src\
文件 1096 2011-10-14 17:37 myjavatest\com\xie\src\MyJavaTest.class
文件 5889 2011-10-14 17:37 myjavatest\com\xie\src\MyJavaTest.java
文件 319 2011-10-14 17:37 myjavatest\com\xie\src\node.class
文件 4297 2011-10-14 17:37 myjavatest\com\xie\src\tree.class
- 上一篇:java程序自动重新启动
- 下一篇:jdbc 读取表结构
相关资源
- java图片浏览器跨平台运行程序与源码
- 基于java的在线考试系统-毕业设计
- 微博系统(Java源码,servlet+jsp),适
- java串口通信全套完整代码-导入eclip
- jsonarray所必需的6个jar包.rar
- 三角网构TIN生成算法,Java语言实现
- java代码编写将excel数据导入到mysql数据
- Java写的cmm词法分析器源代码及javacc学
- JAVA JSP公司财务管理系统 源代码 论文
- JSP+MYSQL旅行社管理信息系统
- 推荐算法的JAVA实现
- 基于Java的酒店管理系统源码(毕业设
- java-图片识别 图片比较
- android毕业设计
- java23种设计模式+23个实例demo
- java Socket发送/接受报文
- JAVA828436
- java界面美化 提供多套皮肤直接使用
- 在线聊天系统(java代码)
- 基于Java的图书管理系统807185
- java中实现将页面数据导入Excel中
- java 企业销售管理系统
- java做的聊天系统(包括正规课程设计
- Java编写的qq聊天室
- 商店商品管理系统 JAVA写的 有界面
- JAVA开发聊天室程序
- 在linux系统下用java执行系统命令实例
- java期末考试试题两套(答案) 选择(
- JAVA3D编程示例(建模、交互)
- Java 文件加密传输
评论
共有 条评论