有趣的小算法

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

相关推荐
handler016 分钟前
算法:Trie树(字典树)
c语言·数据结构·c++·笔记·算法·深度优先
不漫游6 分钟前
Web聊天室测试报告
java
ZPC82107 分钟前
PPO (Proximal Policy Optimization) 算法模块详细拆解
人工智能·pytorch·算法·机器人
阿Y加油吧10 分钟前
力扣打卡day06——滑动窗口最大值、最小覆盖子串
数据结构·算法·leetcode
沉鱼.4411 分钟前
日期题目集
数据结构·算法
MegaDataFlowers12 分钟前
依赖注入(DI)
java·开发语言
晓纪同学18 分钟前
EffctiveC++_01第一章
java·开发语言·c++
zhen_hong19 分钟前
ReactAgent原理
android·java·javascript
Book思议-19 分钟前
【数据结构考研真题】链表题
c语言·数据结构·算法·链表·408·计算机考研
汤姆yu19 分钟前
IDEA使用通义灵码做现有项目迭代开发保姆级教程
java·ide·intellij-idea·灵码