资源简介
本代码由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程序自动重新启动
- 数据库课程设计(JDBC+Swing)高校教材
- java实现简单的记事本程序内含源代码
- java在线客服聊天
- 《java技术开发大全》随书光盘源代码
- Java的输入输出流实现文件的复制
- java web实现文件的上传
- JAVAWEB批量文件器
- jaf-1_1_1.zip
- 使用java编写的简单的网络五子棋
- 《Java基础入门》_课后习题答案
- Java 汉诺塔_Hannoi GUI 可视化_图形用户
- 西安软件公司java笔试题
- Java解析fsn文件
- 会议室预定系统的Java实现
- jsp+web+简单学生管理系统+mysql
- JAVA实现的网络白板
- Java 画图板基本图形、撤销、清空、重
- java爬虫完整代码
- java mrp算法实现
- SuperVCD纯JAVA编程
- Java汪文君高并发编程.txt
- 汪文君Java8新特性及实战视频教程完整
- 用java写的多线程聊天程序GUI界面soc
- java课程设计系列之魔板游戏.rar
- java用servlet实现文件上传到数据库
- JAVA贪吃蛇源代码
- java绘图程序代码
- java 一笔画问题
- Java私塾——模拟银行系统源代码
评论
共有 条评论