zoukankan      html  css  js  c++  java
  • JDK8 HashMap--treeify()树形化方法

     1   /*创建红黑树*/
     2     final void treeify(Node<K,V>[] tab) {
     3             TreeNode<K,V> root = null;// 定义红黑树根节点root
     4             for (TreeNode<K,V> x = this, next; x != null; x = next) {// 循环,定义x:循环变量,代表当前节点、next:当前节点的后继元
     5                 next = (TreeNode<K,V>)x.next;
     6                 x.left = x.right = null;// 初始化当前节点x的左子节点、右子节点
     7                 if (root == null) {// 若root为空,表明首次循环此时x指向的节点为根节点
     8                     x.parent = null;// 根节点无父节点
     9                     x.red = false;// 根节点为黑色
    10                     root = x;
    11                 }
    12                 else {// 除首次循环外其余均走这个分支
    13                     K k = x.key;// 获取当前节点的key与hash值
    14                     int h = x.hash;
    15                     Class<?> kc = null;// 定义key的Class对象kc
    16                     for (TreeNode<K,V> p = root;;) {// 循环,每次循环从根节点开始,寻找位置
    17                         int dir, ph;// 定义节点相对位置、节点p的hash值
    18                         K pk = p.key;// 获取节点p的key
    19                         if ((ph = p.hash) > h)
    20                             dir = -1;// 当前节点在节点p的左子树
    21                         else if (ph < h)
    22                             dir = 1;// 当前节点在节点p的右子树
    23                         else if ((kc == null &&
    24                                   (kc = comparableClassFor(k)) == null) ||
    25                                  (dir = compareComparables(kc, k, pk)) == 0)
    26                             dir = tieBreakOrder(k, pk);// 当前节点与节点p的hash值相等,当前节点key并没有实现Comparable接口或者实现Comparable接口并且与节点pcompareTo相等,该方法是为了保证在特殊情况下节点添加的一致性用于维持红黑树的平衡
    27 
    28                         TreeNode<K,V> xp = p;
    29                         if ((p = (dir <= 0) ? p.left : p.right) == null) {// 根据dir判断添加位置也是节点p的左右节点,是否为空,若不为null在p的子树上进行下次循环
    30                             x.parent = xp;// 若添加位置为null,建立当前节点x与父节点xp之间的联系
    31                             if (dir <= 0)// 确定当前节点时xp的左节点还是右节点
    32                                 xp.left = x;
    33                             else
    34                                 xp.right = x;
    35                             root = balanceInsertion(root, x);// 对红黑是进行平衡操作并结束循环
    36                             break;
    37                         }
    38                     }
    39                 }
    40             }
    41             moveRootToFront(tab, root);// 将红黑树根节点复位至数组头结点
    42         }
  • 相关阅读:
    ArcGIS数据建模 (模型构建器modelbuilder) 培训视频 5章28小节587分钟视频 51GIS网站上线
    arcgis python ListEnvironments 函数可返回地理处理环境名称列表。
    arcgis python ValueTable使用
    解决ArcMap启动时只停留在初始化界面的方法
    Eutils用法总结
    EF 汇总函数使用注意事项Max()/Min()等
    C#多线程
    EF Attach时报错
    [Windows报错]要求的函数不受支持、这可能是由于 CredSSP 加密 Oracle 修正
    C#遍历XmlDocument对象所有节点名称、类型、属性(Attribute)
  • 原文地址:https://www.cnblogs.com/flydoging/p/10384773.html
Copyright © 2011-2022 走看看