red-black Tree
Red-Black trees provide a slightly relaxed balancing condition, so the tree can be a little more imbalanced than AVL trees. The benefit is that the insertion and removal algorithms are faster. The drawback is that look-up(i.e., a find()) is a little slower. However, since a look-up is O(logN)in both cases, the slight constant increase in this operation is usually unnoticeable, while the insert() and remove() speed improvements are clear.
红黑树是一种稍微没有那么balanced的balanced Tree, 查询速度稍稍慢了一点点,但是插入和删除都超级快。
资料:https://www.cnblogs.com/CarpenterLee/p/5503882.html
https://www.cnblogs.com/skywang12345/p/3245399.html
data:image/s3,"s3://crabby-images/c4afb/c4afb521e9e262bee5c6d4db9ae01157ce5b2f99" alt=""
插播AVL TREE:
data:image/s3,"s3://crabby-images/543ec/543eccf7347825b75f023585e3477db6d7ef6484" alt=""
data:image/s3,"s3://crabby-images/c22a4/c22a4a24a71c41225e2e8a57e26c604fe14e5979" alt=""
AVL delete 需要使用rotation
data:image/s3,"s3://crabby-images/14085/14085b3781dca1682c908778229f52fa3d34ac1b" alt=""
data:image/s3,"s3://crabby-images/c2c31/c2c31a6f569de09371cae3fa128f5cc8617673f4" alt=""
Insertion:
data:image/s3,"s3://crabby-images/fbaf4/fbaf4b0c78566cf844ccd0a26ccb4b33d132ac7c" alt=""
data:image/s3,"s3://crabby-images/d2f36/d2f368f83f65f3596f6ad4f44af386163ce3b740" alt=""
AVL Tree 比 red-black tree更balanced,但是需要更多的rotations during insertion & deletion, 所以如果需要经常删除,添加 还是Red-black tree比较好。
data:image/s3,"s3://crabby-images/7ae10/7ae102569ea4e06d32caa7d9df94613c58135013" alt=""
Root and Leafs 都是blacks.
data:image/s3,"s3://crabby-images/24308/24308d440c944c0f792de8f06612481508118b6f" alt=""