求反序数

CUG_JaySun 2015-10-17 11:28:27
这段代码可以执行,但是为什么输入10位数以上就出现错误?

#include<iostream>
#include<string>
#include<cmath>
using namespace std;
int main()
{ //数字逆序 //位数
int digits = 1;
int testDig = 0;
cin>>testDig;
int tmp = testDig;
if(abs(testDig) > 10)
{
while(abs(tmp) > 10)
{
tmp = abs(tmp) / 10;
digits++;
}
}
cout<<digits<<endl;
//逆序输出
tmp = testDig;
for(int cycle = 0; cycle <= digits; ++cycle)
{
cout<<abs(tmp) %10;
tmp = abs(tmp) / 10;
}
if(testDig < 0)
{
cout<<"-"<<endl;
}

//system("pause");
return 0;
}
...全文
183 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
paschen 版主 2015-10-17
  • 打赏
  • 举报
回复
int 是有范围的,超出则会溢出,导致数据不正常 如果需要很大的数,可以使用long long
fefe82 2015-10-17
  • 打赏
  • 举报
回复
32 位的 int 最大是 2147483647 ,十位以上很容易就超过了。

64,639

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧