计算大 N 的 2^n
calculate 2^n for large N
本文关键字:计算 更新时间:2023-10-16
我想为 N 的大值计算 2^N,即使用 mod 操作最多 10^9。使用了迭代方法,但输入 10^8 需要花费大量时间。
for(long i=1;i<=n;i++){
res=(res*2)%1000000007
}
计算 n=10^8 及以上需要时间。
您可以通过平方和乘以 2 来提高速度 - 例如 2^4 可以达到 2*2 => 4, 4*4 => 16。
从 2 开始。如果 N 是偶数,则对现有内容进行平方并将 N 减半。如果 N 是奇数,则乘以 2 并递减 N.边走边应用模数。
您可能需要小心平方不会溢出。
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 递归函数计算序列中的平方和(并输出过程)
- (C++)分析树以计算返回错误值的简单算术表达式
- 我的字符计数代码计算错误.为什么
- 在计算中使用二的幂有多有利可图
- 如何计算文件中的"columns"数?
- 计算排序向量的向量中唯一值的计数
- 如何使用 std::累积在 C++ 中计算总和立方体
- 使用Qt C++计算类似Git的SHA1哈希
- OpenCV C++.快速计算混淆矩阵
- cpp二进制搜索问题,计算给定数组中输入元素的出现次数
- C++如何计算用户输入的数字中的偶数位数
- 如何计算数据类型的范围,例如int
- 类似枚举的计算常量
- 计算每个节点的树高,帮助我解释这个代码解决方案
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 计算缩放多边形的比例,得到给定的多边形面积
- 在C++中如何在没有pow的情况下进行基础计算
- 计算平均值,不包括上次得分
- 如何计算多映射中重复对的数量