有趣的小算法

找到一个大于等于目标容量的最小的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

相关推荐
程序员卷卷狗4 分钟前
联合索引的最左前缀原则与失效场景
java·开发语言·数据库·mysql
纪莫5 分钟前
技术面:SpringCloud(SpringCloud有哪些组件,SpringCloud与Dubbo的区别)
java·spring·java面试⑧股
会编程的吕洞宾29 分钟前
Java中的“万物皆对象”:一场编程界的哲学革命
java·后端
会编程的吕洞宾37 分钟前
Java封装:修仙界的"护体罡气"
java·后端
豆沙沙包?37 分钟前
2025年--Lc231-350. 两个数组的交集 II-Java版
java·开发语言
Kt&Rs43 分钟前
11.9 LeetCode 题目汇总与解题思路
算法·leetcode
好学且牛逼的马1 小时前
【SSM 框架 | day27 spring MVC】
java
是烟花哈1 小时前
后端开发CRUD实现
java·开发语言·spring boot·mybatis
ゞ 正在缓冲99%…1 小时前
leetcode1547.切棍子的最小成本
数据结构·算法·leetcode·动态规划
爱分享的鱼鱼1 小时前
Java基础(六:线程、线程同步,线程池)
java·后端