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

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

题目

代码

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)

相关推荐
麦烤楽鸡翅几秒前
挡住洪水 (牛客)
java·数据结构·c++·python·算法·bfs·牛客
MicroTech2025几秒前
微算法科技(NASDAQ MLGO)采用动态层次管理和位置聚类技术,修改pBFT算法以提高私有区块链网络运行效率
科技·算法·聚类
~~李木子~~1 分钟前
五子棋项目Alpha-Beta剪枝与MCTS+神经网络实现人机对弈算法对比报告
神经网络·算法·剪枝
bigdata-rookie1 分钟前
JVM 垃圾收集器介绍
java·jvm·算法
ʚ希希ɞ ྀ3 分钟前
leeCode hot 100 !!!持续更新中
数据结构·算法·leetcode
lemontree19453 分钟前
CRC8算法通用版本
算法
热爱生活的猴子4 分钟前
算法322. 零钱兑换
算法
剪一朵云爱着6 分钟前
力扣1539. 第 k 个缺失的正整数
算法·leetcode
摸鱼仙人~12 分钟前
针对编程面试和算法题的基础书籍
算法·面试·职场和发展
京东零售技术31 分钟前
一款AB实验分析智能体是如何诞生的
算法