博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java中如何实现Tree的数据结构算法
阅读量:6183 次
发布时间:2019-06-21

本文共 4311 字,大约阅读时间需要 14 分钟。

最近有人老是问我在Java中如何实现Tree的数据结构算法,今天在网上看了一篇关于这方面的代码,拿出来和大家分享一下吧!

代码实现[一]部分

package ChapterEight;   

  
class Tree {   
    class Node {   
        public long value;   
  
        public Node leftChild;   
  
        public Node rightChild;   
  
        public Node(long value) {   
            this.value = value;   
            leftChild = null;   
            rightChild = null;   
        }   
    }   
  
    public Node root;   
  
    public Tree() {   
        root = null;   
    }   
  
    // 向树中插入一个节点   
    public void insert(long value) {   
        Node newNode = new Node(value);   
        // 树是空的   
        if (root == null)   
            root = newNode;   
        else {   
            Node current = root;   
            Node parentNode;   
            while (true) {   
                parentNode = current;   
                if (value < current.value) {   
                    current = current.leftChild;   
                    // 要插入的节点为左孩子节点   
                    if (current == null) {   
                        parentNode.leftChild = newNode;   
                        return;   
                    }   
                } else {   
                    // 要插入的节点为右孩子节点   
                    current = current.rightChild;   
                    if (current == null) {   
                        parentNode.rightChild = newNode;   
                        return;   
                    }   
                }   
            }   
        }   
    }   
  
    // 先续遍历树中的所有节点   
    public void preOrder(Node currentRoot) {   
        if (currentRoot != null) {   
            System.out.print(currentRoot.value + " ");   
            preOrder(currentRoot.leftChild);   
            preOrder(currentRoot.rightChild);   
        }   
    }   
  
    // 中续遍历树中的所有节点   
    public void inOrder(Node currentNode) {   
        if (currentNode != null) {   
            inOrder(currentNode.leftChild);   
            System.out.print(currentNode.value + " ");   
            inOrder(currentNode.rightChild);   
        }   
    }   
  
    // 后续遍历树中的所有节点   
    public void postOrder(Node currentNode) {   
        if (currentNode != null) {   
            postOrder(currentNode.leftChild);   
            postOrder(currentNode.rightChild);   
            System.out.print(currentNode.value + " ");   
        }   
    }   
  
    public void traverse(int traverseType) {   
        switch (traverseType) {   
        case 1:   
            preOrder(root);   
            break;   
        case 2:   
            inOrder(root);   
            break;   
        case 3:   
            postOrder(root);   
            break;   
        default:   
            break;   
        }   

// 依据树节点的值删除树中的一个节点   

    public boolean delete(int value) {   
        // 遍历树过程中的当前节点   
        Node current = root;   
        // 要删除节点的父节点   
        Node parent = root;   
        // 记录树的节点为左孩子节点或右孩子节点   
        boolean isLeftChild = true;   
        while (current.value != value) {   
            parent = current;   
            // 要删除的节点在当前节点的左子树里   
            if (value < current.value) {   
                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 == null)   
                root = current.leftChild;   
            // 要删除的节点为左孩子节点   
            else if (isLeftChild)   
                parent.leftChild = current.leftChild;   
            // 要删除的节点为右孩子节点   
            else  
                parent.rightChild = current.leftChild;   
        }   
        // 要删除的节点没有左孩子节点,有右孩子节点   
        else if (current.leftChild == null) {   
            // 要删除的节点为根节点   
            if (current == root)   
                root = root.rightChild;   
            // 要删除的节点为左孩子节点   
            else if (isLeftChild)   
                parent.leftChild = current.rightChild;   
            // 要删除的节点为右孩子节点   
            else  
                parent.rightChild = current.rightChild;   
        }   
        // 要删除的接节点既有左孩子节点又有右孩子节点   
        else {   
            Node successor = getSuccessor(current);   
            // 要删除的节点为根节点   
            if (current == root)   
                root = successor;   
            // 要删除的节点为左孩子节点   
            else if (isLeftChild)   
                parent.leftChild = successor;   
            // 要删除的节点为右孩子节点   
            else  
                parent.rightChild = successor;   
        }   
        return true;   
    }   
  
    // 找到要删除节点的替补节点   
    private Node getSuccessor(Node delNode) {   
        // 替补节点的父节点   
        Node successorParent = delNode;   
        // 删除节点的替补节点   
        Node successor = delNode;   
        Node current = delNode.rightChild;   
        while (current != null) {   
            // successorParent指向当前节点的上一个节点   
            successorParent = successor;   
            // successor变为当前节点   
            successor = current;   
            current = current.leftChild;   
        }   
        // 替补节点的右孩子节点不为空   
        if (successor != delNode.rightChild) {   
            successorParent.leftChild = successor.rightChild;   
            successor.rightChild = delNode.rightChild;   
        }   
        return successor;   
    }   
}   
  
public class TreeApp {   
    public static void main(String[] args) {   
        Tree tree = new Tree();   
        tree.insert(8);   
        tree.insert(50);   
        tree.insert(45);   
        tree.insert(21);   
        tree.insert(32);   
        tree.insert(18);   
        tree.insert(37);   
        tree.insert(64);   
        tree.insert(88);   
        tree.insert(5);   
        tree.insert(4);   
        tree.insert(7);   
  
        System.out.print("PreOrder : ");   
        tree.traverse(1);   
        System.out.println();   
  
        System.out.print("InOrder : ");   
        tree.traverse(2);   
        System.out.println();   
  
        System.out.print("PostOrder : ");   
        tree.traverse(3);   
        System.out.println();   
  
        System.out.println(tree.delete(7));   
  
        System.out.print("PreOrder : ");   
        tree.traverse(1);   
        System.out.println();   
  
        System.out.print("InOrder : ");   
        tree.traverse(2);   
        System.out.println();   
  
        System.out.print("PostOrder : ");   
        tree.traverse(3);   
        System.out.println();   
  
    }   
}

转载地址:http://vvsda.baihongyu.com/

你可能感兴趣的文章
tomcat下的内存设置,以及设置tomcat内存参数的查看
查看>>
django搭建博客网站
查看>>
《linux Shell 脚本攻略》进阶学习(第一部分)
查看>>
java 邮件收发
查看>>
我的友情链接
查看>>
mysql root 管理软件
查看>>
jquery mobile自动弹出popup
查看>>
hash注入神器WCE发布1.4 Beta版本
查看>>
CloudFoundry DEA运作源码分析
查看>>
SQL --索引
查看>>
快速排序
查看>>
在MyEclipse中创建Java Maven依赖项目
查看>>
《我的前半生》观后感
查看>>
高可用性及容灾的几个衡量指标
查看>>
Mysql最后补充+Java连接数据库
查看>>
前台语言与后台语言的本质区别
查看>>
机器学习实战第三章决策树
查看>>
Linux软件包安装和卸载(yum)
查看>>
添加device
查看>>
Kubernetes 之 kubeadm最佳实践
查看>>