数据结构
从0到1哦
喜欢大数据行业,热爱技术,时刻追随着大数据的发展
展开
-
Java7/8 中的 HashMap 和 ConcurrentHashMap 全解析(上)
Java7 HashMap HashMap 是最简单的,一来我们非常熟悉,二来就是它不支持并发操作,所以源码也非常简单。 首先,我们用下面这张图来介绍 HashMap 的结构。 大方向上,HashMap 里面是一个数组,然后数组中每个元素是一个单向链表。 上图中,每个绿色的实体是嵌套类 Entry 的实例,Entry 包含四个属性:key, value, hash 值和用于单向链表的 next。...原创 2018-12-02 20:23:38 · 207 阅读 · 0 评论 -
Java7/8 中的 HashMap 和 ConcurrentHashMap 全解析(下)
Java8 HashMap Java8 对 HashMap 进行了一些修改,最大的不同就是利用了红黑树,所以其由 数组+链表+红黑树 组成。 根据 Java7 HashMap 的介绍,我们知道,查找的时候,根据 hash 值我们能够快速定位到数组的具体下标,但是之后的话,需要顺着链表一个个比较下去才能找到我们需要的,时间复杂度取决于链表的长度,为 O(n)。 为了降低这部分的开销,在 Java8 ...原创 2018-12-02 20:40:57 · 97 阅读 · 0 评论 -
关于平衡二叉树的那点事
一、概念 平衡二叉搜索树(Self-balancing binary search tree)又被称为AVL树(有别于AVL算法),且具有以下性质:它是一 棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。平衡二叉树的常用实现方法有红黑树、AVL、替罪羊树、Treap、伸展树等。 最小二叉平衡树的节点总数的公式如下 F(n)=F(n-1)+F(n-2)+1 这个...原创 2018-11-27 19:12:31 · 155 阅读 · 0 评论