前序遍历:中,左,右
中序遍历:左,中,右
后序遍历:左,右,中
二叉树查找
从根节点进行比较,目标比根节点小,指针移动到左边
从根节点进行比较,目标比根节点大,指针移动到右边
/** * 前序遍历 * @param tree */ public void preOrder(BSTree tree){ preOrder(tree.mRoot); } preOrder(BSTNode node){ if(node!=null){ System.out.print(node.key+""); preOrder(node.left); preOrder(node.right); } } * 中序遍历 * midOrder(BSTree tree){ midOrder(tree.mRoot); } midOrder(BSTNode node){ ){ midOrder(node.left); System.out.print(node.key+""); midOrder(node.right); } } * 后序遍历 * postorder(BSTree tree){ postorder(tree.mRoot); } postorder(BSTNode node){ ){ postorder(node.left); postorder(node.right); System.out.print(node.key+""); } } * 二叉树的查找 * tree * key * @return public BSTNode<T> search(BSTree<T> tree,T key){ BSTNode<T> mRoot=tree.mRoot; while(mRoot!=){ int flag=key.compareto(mRoot.key); if(flag<0){ mRoot=mRoot.left; }else if(flag>0mRoot.right; }else{ return mRoot; } } 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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。