计算函数中的模给出了与直接使用%运算符不同的答案
Calculating modulus in a function gives different answer from using % operator directly
my_mod.cpp:
#include <iostream>
using namespace std;
unsigned int my_mod(int a, unsigned int b)
{
int result;
cout << "tat=t" << a << endl;
cout << "tbt=t" << b << endl;
cout << "ta%bt=t" << a%b << endl;
result = a%b;
if (result < 0) {result += b;}
return result;
}
int main()
{
cout << "-1%5 = " << -1%5 << endl;
cout << "my_mod(-1,5) = " << my_mod(-1,5) << endl;
return 0;
}
编译方式:g++/my_mod.cpp
结果在:
-1%5 = -1
a = -1
b = 5
a%b = 0
my_mod(-1,5) = 0
这里到底发生了什么我只是不明白可能会发生什么?!这不可能是由于全球范围,对吧?!我的意思是,这是完全相同的%-表达式。。。他们怎么能得到0和-1?!(顺便说一下,不是想要的4。)
请,如果有人可以的话,向我解释一下。。。我只花了几天时间就把一个更广泛的错误缩小到了这个范围。说真的,我快要哭了。
在上面的例子中,我如何使我的(全局)自己的模量返回4??
这是因为您使用的是无符号的int,有符号的int(-1)被提升为-1%UINT_MAX,因此您的操作变为(-1%UINT_MAX)%5=0(感谢jrok提供了更详细的原因)
尝试
cout << "ta%bt=t" << a%(int)b << endl;
result = a%(int)b;
函数签名为:int my_mod(int a,unsigned int b)
或者只使用函数签名:int my_mod(int a,int b)
相关文章:
- 为什么比较运算符如此快速
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 欧拉项目#8答案是大以获得有效答案
- 增量运算符与后缀混淆
- 一个关于在C++中重载布尔运算符的问题
- 首要问题的答案让值班员搞错了
- 运算符C++ "delete []"仅删除 2 个前值
- 模板类无法识别友元运算符
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 关闭||运算符优化
- 通过继承类使用来自不同命名空间的运算符
- C++Cast运算符过载
- 如何使用AngelScript注册SFML Vector2运算符
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 尝试重载 c++ 中的后增量运算符,但答案与预期不符
- 计算函数中的模给出了与直接使用%运算符不同的答案
- 我没有得到我期望使用按位not运算符的答案.我很感激你的帮助