棋盘放麦子【指数爆炸问题】--位运算:左/右移--对数据溢出的理解

棋盘放麦子【指数爆炸问题】--对数据溢出的理解

题目

代码

cpp 复制代码
#include <iostream>
using namespace std;

int main() {
    // 正确实现:使用无符号类型和位运算
    unsigned long long total = (1ULL << 63) * 2 - 1; 
     //2^0 + 2^1 + ... + 2^63 = 2^64 - 1【等比数列公式得出】 等价2^64-1
    //位运算 【左移】 1ULL << 63能精确表示2^63,再乘2得到2^64
    
    左移运算<<是CPU基础指令,比函数调用(如pow)快数千倍
    但是 左/右移运算的优先级小于运算符,固一定要加括号
    左移=2的n次方
    右移运算=除以2
    
    cout << total;  // 输出18446744073709551615
    return 0;
}

数据类型的选择

判断正负:

需要负数 → 选有符号类型(int, long)

只需非负 → 选无符号(unsigned...,容量翻倍)

1ULL是什么

1ULL是什么?

字母含义:

U → 无符号(Unsigned,只存非负数)

LL → 超长整型(Long Long,64位存储)

遇到溢出怎么办:

现象:正数变负数/结果异常小

对策:升级到更大的类型(如int→long→unsigned long long)

相关推荐
张小姐的猫21 小时前
【Linux】进程信号(质变)—— 信号捕捉 | 中断 | 内核态
linux·运维·服务器·c++
佩洛君21 小时前
如何在Ubuntu22.04中安装ROS2-Humble
c++·python·ros2
不会写DN21 小时前
为什么map查找时间复杂度是O(1)?
算法·哈希算法·散列表
iiiiyu21 小时前
常用API(StringJoiner类 & Math类 & System类)
java·大数据·开发语言·数据结构·编程语言
始三角龙1 天前
LeetCode hoot 100 -- 找到字符串中的所有字母异位词
算法·leetcode·职场和发展
abant21 天前
leetcode 45 跳跃问题2 很难的贪心
算法·leetcode·职场和发展
小糯米6011 天前
C语言指针3
c语言·数据结构·算法
ZPC82101 天前
ROS2 通信提速快过UDP
人工智能·算法·机器人
RD_daoyi1 天前
谷歌2026年 3 月核心更新深度解析:SEO 从内容优化到信息供给系统的全面重构
人工智能·算法·重构
Xiu Yan1 天前
Java 转 C++ 系列:函数对象、谓词和内建函数对象
java·开发语言·c++