方法一(delNode):若为非叶子结点将此结点的树直接删除(代码163行)
方法二(delNode1):若为非叶子结点(代码188行)
若只有一个子结点,让该子节点代替结点
若结点为a,左子结点为b,右子接点为c,让b结点代表a
package tree;
public class BinaryTreeAPP {
public static void main(String[] args) {
// TODO 自动生成的方法存根
HeroNode root=new HeroNode(1, "宋江");
HeroNode node1=new HeroNode(2, "吴用");
HeroNode node2=new HeroNode(3, "卢俊义");
HeroNode node3=new HeroNode(4, "林冲");
HeroNode node4=new HeroNode(5, "关胜");
root.setLeft(node1);
root.setRight(node2);
node2.setRight(node3);
node2.setLeft(node4);
BinaryTree binaryTree=new BinaryTree(root);
System.out.println("删除结点前:");
System.out.println("前序排序");
binaryTree.preOrder();
System.out.println("中序排序");
binaryTree.midOrder();
System.out.println("后序排序");
binaryTree.postOrder();
binaryTree.delNode1(3);
System.out.println("删除结点后:");
System.out.println("前序排序");
binaryTree.preOrder();
System.out.println("中序排序");
binaryTree.midOrder();
System.out.println("后序排序");
binaryTree.postOrder();
}
}
//树
class BinaryTree{
private HeroNode root;
public BinaryTree(HeroNode root) {
this.root=root;
}
//调用前序遍历
public void preOrder() {
if(root!=null) {
root.preOrder();
}else {
System.out.println("根节点为空 ");
}
}
//调用中序遍历
public void midOrder() {
if(root!=null) {
root.midOrder();
}else {
System.out.println("根节点为空 ");
}
}
//调用后序遍历
public void postOrder() {
if(root!=null) {
root.postOrder();
}else {
System.out.println("根节点为空 ");
}
}
//调用删除结点方法
public void delNode(int no) {
if(root!=null) {
root.delNode(root, no);
}else {
System.out.println("根节点为空 ");
}
}
//调用删除节点方法一
public void delNode1(int no) {
if(root!=null) {
root.delNode1(root, no);
}else {
System.out.println("根节点为空 ");
}
}
}
//结点
//回溯遍历
class HeroNode{
private int no;
private String name;
private HeroNode left;
private HeroNode right;
public HeroNode(int no,String name) {
this.setNo(no);
this.setName(name);
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public HeroNode getLeft() {
return left;
}
public void setLeft(HeroNode left) {
this.left = left;
}
public HeroNode getRight() {
return right;
}
public void setRight(HeroNode right) {
this.right = right;
}
public int getNo() {
return no;
}
public void setNo(int no) {
this.no = no;
}
public void show() {
System.out.println("HeroNode [no="+no+",name="+name+"]");
}
//前序遍历
public void preOrder() {
this.show();
if(this.left!=null) {
this.left.preOrder();
}
if(this.right!=null) {
this.right.preOrder();
}
}
//中序遍历
public void midOrder() {
if(this.left!=null) {
this.left.midOrder();
}
this.show();
if(this.right!=null) {
this.right.midOrder();
}
}
//后序遍历
public void postOrder() {
if(this.left!=null) {
this.left.postOrder();
}
if(this.right!=null) {
this.right.postOrder();
}
this.show();
}
//删除结点(若为非叶子结点将此结点的树直接删除)
public void delNode(HeroNode temp,int flag){
if(temp.left!=null&&temp.left.no==flag){
temp.left=null;
return;
}
if(temp.right!=null&&temp.right.no==flag){
temp.right=null;
return;
}
if(temp.left!=null){
delNode(temp.left,flag);
}
if(temp.right!=null){
delNode(temp.right,flag);
}
System.out.println("未找到此结点");
}
//删除结点(若为非叶子结点)
//若只有一个子结点,让该子节点代替结点
//若结点为a,左子结点为b,右子接点为c,让b结点代表a
//node:待删除结点的父节点
public void delNode1(HeroNode node,int flag){
if(node.left!=null&&node.left.no==flag){//匹配成功
HeroNode temp=node.left;//temp承载被删除结点
if(temp.left==null&&temp.right==null){//叶子结点
node.left=null;//叶子节点直接删除
}else if(temp.left!=null&&temp.right!=null){//两个子节点
temp.left.right=temp.right;//将被删除结点的左子节点的右子节点指向被删除结点子节点的右子节点
node.left=temp.left;//被删除结点的父节点的左子节点指向被删除节点的左子节点(被删除字节的左子节点取代被删除节点的位置)
}else if(temp.left!=null&&temp.right==null){//右子结点为空
node.left=temp.left;
}else if(temp.right!=null&&temp.left==null){//左子结点为空
node.left=temp.right;
}
return;
}
if(node.right!=null&&node.right.no==flag){//匹配成功
HeroNode temp=node.right;
if(temp.left==null&&temp.right==null){//叶子结点
node.right=null;
}else if(temp.left!=null&&temp.right!=null){//两个子节点
node.right=temp.left;
temp.left.left=temp.right;
}else if(temp.left!=null&&temp.right==null){//右子结点为空
node.right=temp.left;
}else if(temp.right!=null&&temp.left==null){//左子结点为空
node.right=temp.right;
}
return;
}
if(node.left!=null){
delNode(node.left,flag);
}
if(node.right!=null){
delNode(node.right,flag);
}
System.out.println("未找到该结点");
}
}
删除前:
方法一:
方法二: