源碼篇-TreeMap之Floor與Ceiling操作

一、ceiling操作

1、ceilingEntry函數(shù)
public Map.Entry<K,V> ceilingEntry(K key) {
    return exportEntry(getCeilingEntry(key));
}

final Entry<K,V> getCeilingEntry(K key) {
    Entry<K,V> p = root;
    while (p != null) {
        int cmp = compare(key, p.key);
        // 如果小于,那么向左查找,如果左邊為空了,p就是大于key的最小結(jié)點
        if (cmp < 0) {
            if (p.left != null)
                p = p.left;
            else
                return p;
        // 如果大于,一直向右查找,如果右邊為空了,則向上找到第一個左父結(jié)點
       } else if (cmp > 0) {
            if (p.right != null) {
                p = p.right;
            } else {
                Entry<K,V> parent = p.parent;
                Entry<K,V> ch = p;
                while (parent != null && ch == parent.right) {
                    ch = parent;
                    parent = parent.parent;
                }
                return parent;
            }
        // 如果等于直接返回
       } else
            return p;
    }
    return null;
}   
  • ceilingEntry函數(shù)返回的是大于等于指定key的最小結(jié)點,不存在的話返回空
2、ceilingKey函數(shù)
public K ceilingKey(K key) {
    return keyOrNull(getCeilingEntry(key));
}

final Entry<K,V> getCeilingEntry(K key) {
    Entry<K,V> p = root;
    while (p != null) {
        int cmp = compare(key, p.key);
        if (cmp < 0) {
            if (p.left != null)
                p = p.left;
            else
                return p;
        } else if (cmp > 0) {
            if (p.right != null) {
                p = p.right;
            } else {
                Entry<K,V> parent = p.parent;
                Entry<K,V> ch = p;
                while (parent != null && ch == parent.right) {
                    ch = parent;
                    parent = parent.parent;
                }
                return parent;
            }
        } else
            return p;
    }
    return null;
}   
  • ceilingKey函數(shù)返回的是大于等于指定key的最小結(jié)點的key,不存在的話返回空

二、floor操作

1、floorEntry函數(shù)
public Map.Entry<K,V> floorEntry(K key) {
    return exportEntry(getFloorEntry(key));
}

final Entry<K,V> getFloorEntry(K key) {
    Entry<K,V> p = root;
    while (p != null) {
        int cmp = compare(key, p.key);
        // 大于0,向右查找,如果右節(jié)點為空,那么當(dāng)前被比較的結(jié)點就是要找的結(jié)點
        if (cmp > 0) {
            if (p.right != null)
                p = p.right;
            else
                return p;
        // 小于0,向左查找,如果左節(jié)點為空,那么向上找,找的第一個右父結(jié)點就是要找的結(jié)點
       } else if (cmp < 0) {
            if (p.left != null) {
                p = p.left;
            } else {
                Entry<K,V> parent = p.parent;
                Entry<K,V> ch = p;
                while (parent != null && ch == parent.left) {
                    ch = parent;
                    parent = parent.parent;
                }
                return parent;
            }
        // 如果等于直接返回
       } else
            return p;

    }
    return null;
}   
    
  • floorEntry返回小于等于指定key的結(jié)點最大結(jié)點,沒有則返回空
2、floorKey函數(shù)
public K floorKey(K key) {
    return keyOrNull(getFloorEntry(key));
}
final Entry<K,V> getFloorEntry(K key) {
    Entry<K,V> p = root;
    while (p != null) {
        int cmp = compare(key, p.key);
        if (cmp > 0) {
            if (p.right != null)
                p = p.right;
            else
                return p;
        } else if (cmp < 0) {
            if (p.left != null) {
                p = p.left;
            } else {
                Entry<K,V> parent = p.parent;
                Entry<K,V> ch = p;
                while (parent != null && ch == parent.left) {
                    ch = parent;
                    parent = parent.parent;
                }
                return parent;
            }
        } else
            return p;

    }
    return null;
}   
  • floorKey返回小于等于指定key的結(jié)點最大結(jié)點的key,沒有則返回空

三、higher操作

1、higherEntry函數(shù)
public Map.Entry<K,V> higherEntry(K key) {
    return exportEntry(getHigherEntry(key));
}
final Entry<K,V> getHigherEntry(K key) {
    Entry<K,V> p = root;
    while (p != null) {
        int cmp = compare(key, p.key);
        if (cmp < 0) {
            if (p.left != null)
                p = p.left;
            else
                return p;
        } else {
            if (p.right != null) {
                p = p.right;
            } else {
                Entry<K,V> parent = p.parent;
                Entry<K,V> ch = p;
                while (parent != null && ch == parent.right) {
                    ch = parent;
                    parent = parent.parent;
                }
                return parent;
            }
        }
    }
    return null;
}   
  • higherEntry函數(shù)返回大于指定key的最小結(jié)點,如果不存在返回空

四、lower操作

1、lowerEntry函數(shù)
public Map.Entry<K,V> lowerEntry(K key) {
    return exportEntry(getLowerEntry(key));
}

final Entry<K,V> getLowerEntry(K key) {
    Entry<K,V> p = root;
    while (p != null) {
        int cmp = compare(key, p.key);
        if (cmp > 0) {
            if (p.right != null)
                p = p.right;
            else
                return p;
        } else {
            if (p.left != null) {
                p = p.left;
            } else {
                Entry<K,V> parent = p.parent;
                Entry<K,V> ch = p;
                while (parent != null && ch == parent.left) {
                    ch = parent;
                    parent = parent.parent;
                }
                return parent;
            }
        }
    }
    return null;
}   
  • lowerEntry函數(shù)小于指定key的最大的結(jié)點,如果沒有返回空
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 本篇分析TreeMap。 TreeMap的定義及說明 定義如下: 1、繼承了AbstractMap及實現(xiàn)了Navi...
    swz_android閱讀 213評論 0 1
  • 系列文章:Java集合系列01之概覽Java集合系列02之ArrayList源碼分析Java集合系列03之Link...
    Hengtao24閱讀 203評論 0 1
  • 一、基本數(shù)據(jù)類型 注釋 單行注釋:// 區(qū)域注釋:/* */ 文檔注釋:/** */ 數(shù)值 對于byte類型而言...
    龍貓小爺閱讀 4,454評論 0 16
  • 上篇文章我們介紹了HashMap集合,這是一個鍵值對集合,可以高效的按照鍵查找數(shù)值。但是它有一個缺陷:數(shù)據(jù)如果是無...
    Single_YAM閱讀 254評論 0 3
  • TreeMap簡介 常見的數(shù)據(jù)結(jié)構(gòu)有數(shù)組、鏈表,還有一種結(jié)構(gòu)也很常見,那就是樹。前面介紹的集合類有基于數(shù)組的Arr...
    小帝Ele閱讀 741評論 0 1

友情鏈接更多精彩內(nèi)容