有趣的小算法

找到一个大于等于目标容量的最小的2的幂次方数,常用于实现具有动态扩展能力的数据结构。

示例:HashMap的扩容大小机制。

java 复制代码
static final int tableSizeFor(int cap) {
    int n = cap - 1;
    n |= n >>> 1;
    n |= n >>> 2;
    n |= n >>> 4;
    n |= n >>> 8;
    n |= n >>> 16;
    return (n < 0) ? 1 : (n >= MAXIMUM_CAPACITY) ? MAXIMUM_CAPACITY : n + 1;
}
  • a. 将n无符号右移一位。
  • b. 对原n和右移后的n进行按位或操作。
  • c. 将结果赋值回n。

这样做的目的是为了确保n的二进制表示中的所有非零位都被设置为1。这是因为每次右移一位后,原最高位会被移到次高位,并且按位或操作可以保证只要原来的最高位为1,那么新的次高位也将变为1。重复这个过程直到所有可能的位置都被覆盖到,从而得到大于等于目标容量的最小的2的幂次方数。

当cap = 25,最后返回32

相关推荐
今儿敲了吗5 分钟前
19| 海底高铁
c++·笔记·学习·算法
冰暮流星6 分钟前
javascript之字符串索引数组
开发语言·前端·javascript·算法
Hag_2011 分钟前
LeetCode Hot100 3.无重复字符的最长子串
算法·leetcode·职场和发展
好学且牛逼的马12 分钟前
【Hot100|23-LeetCode 234. 回文链表 - 完整解法详解】
算法·leetcode·链表
小冻梨66612 分钟前
ABC444 C - Atcoder Riko题解
c++·算法·双指针
我命由我1234513 分钟前
Kotlin 面向对象 - 匿名内部类、匿名内部类简化
android·java·开发语言·java-ee·kotlin·android studio·android jetpack
学到头秃的suhian14 分钟前
Redis分布式锁
java·数据库·redis·分布式·缓存
菜鸡儿齐15 分钟前
leetcode-找到字符串中所有字母异位词
算法·leetcode·职场和发展
不想看见40416 分钟前
Combinations -- 回溯法--力扣101算法题解笔记
数据结构·算法
星火开发设计18 分钟前
模板特化:为特定类型定制模板实现
java·开发语言·前端·c++·知识