[javaSE] 数据结构(二叉树-遍历与查找)

前序遍历:中,左,右

中序遍历:左,中,右

后序遍历:左,右,中

 

二叉树查找

从根节点进行比较,目标比根节点小,指针移动到左边

从根节点进行比较,目标比根节点大,指针移动到右边

 

复制代码
    /**
     * 前序遍历
     * @param tree
     */
    public void preOrder(BSTree tree){
        preOrder(tree.mRoot);
    }
    public void preOrder(BSTNode node){
        if(node!=null){
            System.out.print(node.key+"");
            preOrder(node.left);
            preOrder(node.right);
        }
    }
    /**
     * 中序遍历
     * @param tree
     */
    public void midOrder(BSTree tree){
        midOrder(tree.mRoot);
    }
    public void midOrder(BSTNode node){
        if(node!=null){
            midOrder(node.left);
            System.out.print(node.key+"");
            midOrder(node.right);
        }
    }
    /**
     * 后序遍历
     * @param tree
     */
    public void postOrder(BSTree tree){
        postOrder(tree.mRoot);
    }
    public void postOrder(BSTNode node){
        if(node!=null){
            postOrder(node.left);
            postOrder(node.right);
            System.out.print(node.key+"");
        }
    }
    /**
     * 二叉树的查找
     * @param tree
     * @param key
     * @return
     */
    public BSTNode<T> search(BSTree<T> tree,T key){
        BSTNode<T> mRoot=tree.mRoot;
        while(mRoot!=null){
            int flag=key.compareTo(mRoot.key);
            if(flag<0){
                mRoot=mRoot.left;
            }else if(flag>0){
                mRoot=mRoot.right;
            }else{
                return mRoot;
            }
        }
        return mRoot;
    }
复制代码

 

        tree.preOrder(tree);//输出 312546
        tree.midOrder(tree);//输出 123456
        tree.postOrder(tree);//输出 214653
        BSTree.BSTNode node=tree.search(tree, 5);
        System.out.println(node.left.key);//输出 4

 

posted @   唯一客服系统开发笔记  阅读(368)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示
1
chat with us