有趣的小算法

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

相关推荐
无巧不成书021816 小时前
Java数值字面量速查表
java·开发语言·python·开发者·字面量
美式请加冰16 小时前
模拟的介绍和使用
java·开发语言·算法
云泽80816 小时前
蓝桥杯算法精讲:贪心算法之区间问题深度剖析
算法·贪心算法·蓝桥杯
tankeven16 小时前
HJ129 小红的双生数
c++·算法
万能的小裴同学16 小时前
C++ 简易的FBX查看工具
开发语言·c++·算法
Boop_wu16 小时前
[Java 算法] 前缀和(2)
算法·哈希算法·散列表
菜菜小狗的学习笔记16 小时前
剑指Offer算法题(二)栈、队列、堆
java·开发语言
李宥小哥17 小时前
SQLite04-表数据管理
java·jvm·数据库
李宥小哥17 小时前
SQLite05-常用函数
java·开发语言·jvm
huohuopro17 小时前
idea配置servlet项目
java·servlet·intellij-idea