二叉树(Java)

由于在有序数组中插入数据项太慢,在链表中查找太慢,而树是兼有这两种性能的数据结构。


class treeNode {
	public int iData;
	public double dData;
	public treeNode leftChild;
	public treeNode rightChild;
	
	public void displayNode() {
		System.out.print("{");
		System.out.print(iData);
		System.out.print(",");
		System.out.print(dData);
		System.out.print("}");
	}
}

public class tree {
	private treeNode root;
	
	public tree() {
		root = null;
	}
	
	public treeNode find(int key) {
		treeNode current = root;
		while(current != null) {
			if(current.iData == key) return current;
			else if(current.iData > key) current = current.leftChild;
			else current = current.rightChild;
		}
		return null;
	}
	
	public void insert(int id, double dd) {
		treeNode newNode = new treeNode();
		newNode.iData = id;
		newNode.dData = dd;
		if(root == null)
			root = newNode;
		else {
			treeNode current = root;
			treeNode parent = current;
			while(true) {
				if(current.iData > id) {
					current = current.leftChild;
					if(current == null) {
						parent.leftChild = newNode;
						return;
					}
				}
				else if(current.iData < id) {
					current = current.rightChild;
					if(current == null) {
						parent.rightChild = newNode;
						return;
					}
				}
				else return;		
			}
		}
	}
	
	public void traverse(int traverseType) {
		switch(traverseType) {
		case 1:
			System.out.println("PreOrder:");
			preOrder(root);
			break;
		case 2:
			System.out.println("InOrder:");
			inOrder(root);
			break;
		case 3:
			System.out.println("PostOrder:");
			postOrder(root);
			break;
		default:
			System.out.println("Initial.");
			break;
		}
	}
	
	//中序遍历,左子树-根节点-右子树
	private void inOrder(treeNode localRoot) {
		if(localRoot != null) {
			inOrder(localRoot.leftChild);
			System.out.print(localRoot.iData + " ");
			inOrder(localRoot.rightChild);
		}
	}
	
	//前序遍历,根节点-左子树-右子树
	private void preOrder(treeNode localRoot) {
		if(localRoot != null) {
			System.out.print(localRoot.iData + " ");
			preOrder(localRoot.leftChild);
			preOrder(localRoot.rightChild);
		}
	}
	
	//后序遍历,左子树-右子树-根节点
	private void postOrder(treeNode localRoot) {
		if(localRoot != null) {
			postOrder(localRoot.leftChild);
			postOrder(localRoot.rightChild);
			System.out.print(localRoot.iData + " ");
		}
	}
	
	public boolean delete(int key) {
		treeNode current = root;
		treeNode parent = root;
		boolean isLeftChild = true;
		
		while(current.iData != key) {
			parent = current;
			if(current.iData > key) {
				isLeftChild = true;
				current = current.leftChild;
			}
			else {
				isLeftChild = false;
				current = current.rightChild;
			}
			if(current == null) return false;
		}
		
		//删除的节点是叶子节点,可直接删除
		if(current.leftChild == null && current.rightChild == null) {
			if(current == root) {
				root = null;
			}
			else if(isLeftChild) {
				parent.leftChild = null;
			}
			else
				parent.rightChild = null;
		}
		
		//删除的节点有左子节点,直接将左子节点上移
		else if(current.rightChild == null) {
			if(current == root) 
				root = current.leftChild;
			else if(isLeftChild)
				parent.leftChild = current.leftChild;
			else
				parent.rightChild = current.leftChild;
		}
		
		//删除的节点有右子节点,直接将右子节点上移
		else if(current.leftChild == null) {
			if(current == root)
				root = current.rightChild;
			else if(isLeftChild)
				parent.leftChild = current.rightChild;
			else
				parent.rightChild = current.rightChild;
		}
		
		//删除的节点有左右两个子节点,让后继节点代替
		else {
			treeNode successor = getSuccessor(current);
			if(current == root)
				root = successor;
			else if(isLeftChild)
				parent.leftChild = successor;
			else
				parent.rightChild = successor;
			successor.leftChild = current.leftChild;
		}
		return true;
	}
	
	private treeNode getSuccessor(treeNode delNode) {
		treeNode successorParent = delNode;
		treeNode successor = delNode;
		treeNode current = delNode.rightChild;
		while(current != null) {
			successorParent = successor;
			successor = current;
			current = current.leftChild;
		}
		if(successor != delNode.rightChild) {
			successorParent.leftChild = successor.rightChild;
			successor.rightChild = delNode.rightChild;
		}
		return successor;
	}
	
	public static void main(String[] args) {
		tree t = new tree();
		t.insert(50, 1.5);
		t.insert(25, 1.2);
		t.insert(75, 1.7);
		t.find(50).displayNode();
		t.traverse(2);
		t.traverse(1);
		t.traverse(3);
		t.delete(75);
		t.traverse(2);
	}
}

还看到了两个概念:

满二叉树:除最后一层无任何子节点外,每一层上的所有结点都有两个子结点的二叉树。

完全二叉树:与满二叉树形态类似,但是最后一层并没有满。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值