有趣的小算法

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

相关推荐
ChoSeitaku几秒前
高数强化NO6|极限的应用|连续的概念性质|间断点的定义分类|导数与微分
人工智能·算法·分类
m0_598177233 分钟前
Mysql(2) - DQL-基本查询
java
代码游侠6 分钟前
学习笔记——栈
开发语言·数据结构·笔记·学习·算法
自然语8 分钟前
人工智能之数字生命-情绪
人工智能·算法
编程修仙12 分钟前
第七篇 java的注解以及使用反射实现自定义注解功能
xml·java·开发语言·spring
f***147714 分钟前
Tomcat10下载安装教程
java
Ayanami_Reii17 分钟前
进阶数据结构应用-维护序列
数据结构·算法·线段树
_w_z_j_23 分钟前
mari和shiny() (多状态dp数组)
算法
lusasky26 分钟前
Java内存堆栈AI分析工具全览
java·开发语言
CoderYanger27 分钟前
C.滑动窗口-越长越合法/求最短/最小——2904. 最短且字典序最小的美丽子字符串
java·开发语言·数据结构·算法·leetcode·1024程序员节