有趣的小算法

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

相关推荐
WL_Aurora1 分钟前
Python 算法基础篇之什么是算法
python·算法
呱牛do it8 分钟前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 7)
java·vue
墨染天姬8 分钟前
[AI]DeepSeek-R1的GRPO算法
人工智能·算法·php
D_C_tyu11 分钟前
JavaScript | 数独游戏核心算法实现
javascript·算法·游戏
qiqsevenqiqiqiqi12 分钟前
MT2048三连 暴力→数学推导→O (n) 优化
数据结构·c++·算法
NE_STOP15 分钟前
Redis--SDS字符串与集合的底层实现原理
java
码之气三段.18 分钟前
十五届山东ccpc省赛补题(update)
数据结构·c++·算法
直奔標竿19 分钟前
Java开发者AI转型第二十二课!Spring AI 个人知识库实战(一)——架构搭建与核心契约落地
java·人工智能·后端·spring·架构
身如柳絮随风扬21 分钟前
深入理解Java IO与NIO的区别:从BIO到NIO的演进
java·nio
A-Jie-Y44 分钟前
JAVA设计模式-抽象工厂模式
java·设计模式