//构建树
public class Binarytree {
TreeNode root;
//设立根节点
public void setRoot(TreeNode root) {
this.root = root;
}
//返回根节点
public TreeNode getRoot() {
return root;
}
//树的前序遍历
public void frontShow(){
if (root!=null)//当根节点不为空时才进行遍历,否则出现空指针异常
root.frontShow();
}
//树的中序遍历
public void middleshow(){
if (root!=null)
root.middleshow();
}
//树的后序遍历
public void aftershow(){
if (root!=null)
root.aftershow();
}
//树的前序查找
public TreeNode frontsearch(int i) {
return root.frontsearch(i);
}
//树的删除子树
public void delete(int i) {
if (root.value==i)
root=null;
else
root.delete(i);
}
}
//构建结点
public class TreeNode {
int value;//树结点中存储的值
TreeNode leftnode;//左儿子
TreeNode rightnode;//右儿子
public TreeNode(int value){
this.value=value;
}
public void setLeftnode(TreeNode node){
this.leftnode=node;
}
public void setRightnode(TreeNode rightnode) {
this.rightnode = rightnode;
}
//前序遍历 根左右
public void frontShow(){
System.out.println(value);
if(leftnode!=null){
leftnode.frontShow();
}
if (rightnode!=null){
rightnode.frontShow();
}
}
//中序遍历 左根右
public void middleshow(){
if(leftnode!=null){
leftnode.middleshow();
}
System.out.println(value);
if (rightnode!=null){
rightnode.middleshow();
}
}
//后序遍历 左右跟
public void aftershow(){
if (leftnode!=null){
leftnode.aftershow();
}
if (rightnode!=null){
rightnode.aftershow();
}
System.out.println(value);
}
//前序查找
public TreeNode frontsearch(int i) {
TreeNode target=null;
if (i==this.value)
return this;
else {
if (leftnode!=null){
target=leftnode.frontsearch(i);//递归调用,如果递归过程中找到了该结点,用target存储该结点,若没找到target仍为null
}
if (target!=null){//代表找到了
return target;
}
if (rightnode!=null){
target=rightnode.frontsearch(i);
}
if (target!=null){
return target;
}
}
return target;//最后执行该语句,代表没找到
}
//删除一个子树
public void delete(int i) {
TreeNode parent=this;
if (parent.leftnode!=null&&parent.leftnode.value==i){//如果该结点的左儿子不为空且value相等
parent.leftnode=null;//删除
return;
}
if (parent.rightnode!=null&&parent.rightnode.value==i){
parent.rightnode=null;
return;
}
//如果左右儿子都不等于i,再向下找,调用递归
parent=leftnode;
if (parent!=null){
parent.delete(i);
}
parent=rightnode;
if (parent!=null){
parent.delete(i);
}
}
}
//主方法
public class TestBaritree {
public static void main(String[] args) {
Binarytree bintree=new Binarytree();
//设置头结点
TreeNode root = new TreeNode(1);
//将头结点赋给树当根节点
bintree.setRoot(root);
TreeNode leftnode = new TreeNode(2);
TreeNode rightnode = new TreeNode(3);
//设置左节点右节点
root.setLeftnode(leftnode);
root.setRightnode(rightnode);
//为第二层结点设置左右结点
leftnode.setLeftnode(new TreeNode(4));
leftnode.setRightnode(new TreeNode(5));
//为第二层结点设置左右结点
rightnode.setLeftnode(new TreeNode(6));
rightnode.setRightnode(new TreeNode(7));
//进行前中后序遍历
//bintree.frontShow();
//bintree.middleshow();
//bintree.aftershow();
TreeNode result=bintree.frontsearch(3);//查找3
System.out.println(result);//出地址值
System.out.println(result==rightnode);//经过地址值对比,是同一个值
//删除一个子树。
bintree.delete(1);
bintree.frontShow();
}
}
二叉树的建立及前中后序遍历及查找指定元素以及删除子树的代码实现
最新推荐文章于 2022-11-27 21:52:54 发布
这篇博客介绍了如何构建一个二叉树,并实现了前序、中序和后序遍历,以及前序查找和删除子树的方法。通过一个具体的Java实例,展示了如何创建树节点,以及在主方法中进行节点设置、遍历和查找操作。
885

被折叠的 条评论
为什么被折叠?



