coolliyong.github.io

常见数据结构

链表

'array' 'array' 'array' 'array'

'stack' 'stack'

队列

'queue' 'queue'

哈希(散列)

'hash' 'hash' 'hash' 'hash' 'hash' 'hash' 'hash' 'hash'

'heap' 'heap' 'heap' 'heap'

二叉查找树

红黑树

红黑树查找

  1. 从根结点开始查找,把根结点设置为当前结点;
  2. 若当前结点为空,返回null;
  3. 若当前结点不为空,用当前结点的key跟查找key作比较;
  4. 若当前结点key等于查找key,那么该key就是查找目标,返回当前结点;
  5. 若当前结点key大于查找key,把当前结点的左子结点设置为当前结点,重复步骤2;
  6. 若当前结点key小于查找key,把当前结点的右子结点设置为当前结点,重复步骤2;

'red black tree find'

非常简单,但简单不代表它效率不好。正由于红黑树总保持黑色完美平衡,所以它的查找最坏时间复杂度为O(2lgN),也即整颗树刚好红黑相隔的时候。能有这么好的查找效率得益于红黑树自平衡的特性,而这背后的付出,红黑树的插入操作功不可没~