Java基于二叉查找树实现排序功能示例
更新时间:2017年08月24日 12:07:23 作者:冷豪
这篇文章主要介绍了Java基于二叉查找树实现排序功能,结合实例形式分析了Java二叉查找树的定义、遍历及排序等相关操作技巧,需要的朋友可以参考下
本文实例讲述了Java基于二叉查找树实现排序功能。分享给大家供大家参考,具体如下:
/** * 无论排序的对象是什么,都要实现Comparable接口 * * @param <T> */ public class BinaryNode<T extends Comparable<T>> { private static int index = 0; // 排序下标 private static int len = 0; // 最大数组长度 private T t; // 根节点 private BinaryNode<T> left; // 左侧叶子节点 private BinaryNode<T> right; // 右侧叶子节点 public BinaryNode(T t) { len++; this.t = t; } /** * 往一颗书中插入值,在本质上都通过根节点一层层的判断。 * 如果根节点不存在则新建节点 * 如果根节点存在则判断应该在左侧还是在右侧插入,通常是左小右大 * * @param t */ public void insert(T t) { if (this.t.compareTo(t) > 0) { if (this.left == null) { BinaryNode<T> node = new BinaryNode<T>(t); this.left = node; } else { this.left.insert(t); } } else { if (this.right == null) { BinaryNode<T> node = new BinaryNode<T>(t); this.right = node; } else { this.right.insert(t); } } } /** * 调用私有方法 * * @return */ public Comparable<?>[] order() { Comparable<?>[] os = new Comparable[len]; order(this, os); return os; } /** * 利用中序遍历查找整颗树 * * @param bn * @param os */ private void order(BinaryNode<T> bn, Comparable<?>[] os) { if (bn.left == null) { os[index++] = bn.t; } else { order(bn.left, os); os[index++] = bn.t; } if (bn.right == null) { return; } else { order(bn.right, os); } } }
更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
相关文章
使用 EasyCode生成springboot+mybatis基础程序的实现示例
本文主要介绍了使用 EasyCode生成springboot+mybatis基础程序的实现示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2022-01-01解决springcloud启动时报错Connection refused:connect问题
这篇文章主要介绍了解决springcloud启动时报错Connection refused:connect问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-05-05
最新评论