操作顺序不正确?(C++)
Order of operations not correct? (C++)
我正在编写一个小型的最不常见多重算法,遇到了一些我不理解的东西。这是代码的第一部分也是最后一部分:
long a = 14159572;
long b = 63967072;
int rest = 4;
long long ans;
.
. // Some other code here that is not very interesting.
.
else
{
//This appears correct, prints out correct answer.
ans = b/rest;
std::cout << a*ans;
}
但如果我把最后一个"else"改成这个,它给出的答案要小得多,也不正确:
else
{
std::cout << a*(b/rest);
}
有人知道为什么会这样吗?我不认为这是一个溢出,因为它不是负数,而是一个比实际答案(大约2.2*10^14)小得多的整数(大约6*10^8)。据我所知,在这两种情况下,它应该首先计算"b/rest",所以答案应该没有区别?
区别不是操作顺序,而是数据类型:
ans = b/rest; // b/rest is long which upscaled to long long
std::cout << a*ans; // a converted to long long and result is long long
vs:
std::cout << a*(b/rest); // a*(b/rest) all calculations in long
因此,如果您将第二个变体更改为:
std::cout << a*static_cast<long long>(b/rest);
你应该看到同样的结果。
更新你的演员阵容不起作用的原因,注意区别:
long a,b;
// divide `long` by `long` and upscale result to `long long`
std::cout << static_cast<long long>( a / b );
// upscale both arguments to `long long` and divide `long long` by `long long`
std::cout << a / static_cast<long long>( b );
您仍然会遇到溢出。仅仅因为你没有观察到负数并不意味着没有溢出。
具体来说,long
几乎可以肯定是32位整数,而long long
可能是64位整数。
由于32位有符号整数的最大值大约为20亿,因此14159572 * (63967072 / 4)
肯定会溢出该范围。
请确保使用long long
数字进行计算,否则请重新考虑代码以避免溢出。
编译器为数学方程的每个操作数假设数据类型,并根据这些假设的数据类型进行乘法和除法运算(请参阅"整数除法")。这也适用于计算的中间环节。这也适用于传递到流的结果,因为您没有传递显式定义类型的变量。
相关文章:
- CMake-按正确顺序将项目与C运行时对象文件链接
- 函数调用中参数的顺序重要吗
- 为什么不;名字在地图上是按顺序排列的吗
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 数到第n个楼梯的路(顺序无关紧要)
- 优先顺序:智能指针和类析构函数
- 在循环中按顺序遍历成员变量
- 独立读取-修改-写入顺序
- QML按钮点击功能执行顺序
- C++中数据类型修饰符的顺序
- 当比特(而不是字节)的顺序至关重要时的持久性
- C++从其他 constexpr 创建 lambda 不能按顺序执行 Constexpr
- 通过选项卡的文本设置QTabWidget顺序
- c++11评估顺序(未定义的行为)
- 如何在C++中递归地按相反顺序打印集合
- 给定顺序中的事件处理
- 具有包含其他对象的类的对象创建顺序
- 如何通过替换顺序代码的while循环来添加OpenMP for循环
- 遍历顺序由 std::文件系统directory_iterator给出
- 检查 2 棵树是否具有相同的顺序