关于整数溢出问题求解

rgcyc 2010-07-12 11:41:51
样例输入
123456789 987654321
0 0

输出应该为
13548070123626141

但我的输出结果是
-7461446

结果显示溢出了,求问如何解决

#include <iostream>
using namespace std;

void change(int *a, int *b)
{
if(*a < *b)
{
int temp = *a;
*a = *b;
*b = temp;
}
}

int gcd(int a, int b)
{
int temp;
change(&a, &b);
while(a%b != 0)
{
temp = a % b;
a = b;
b = temp;
}

return b;
}


int main()
{
long a, b,gcd_result,i = 0;
do{
cin >> a;
cin >> b;
gcd_result = gcd(a,b);
cout << (long)(a*b/gcd_result) << endl;

}while(a != 0 && b != 0);

return 0;
}
...全文
177 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
wqkjj 2010-07-12
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 sujiewen 的回复:]

long最大范围是多少?
用long long或者int64_t试试看
[/Quote]

64位的long long都超出了。需要自己写个大整数的操作类。
sujiewen 2010-07-12
  • 打赏
  • 举报
回复
long最大范围是多少?
用long long或者int64_t试试看
孤之雨 2010-07-12
  • 打赏
  • 举报
回复
int a,int b
a*b的结果还是int,但是已经溢出了~~~~
heimaofj 2010-07-12
  • 打赏
  • 举报
回复
int gcd(int a, int b)
void change(int *a, int *b)

问题出在你的中间变量,你设断点单步运行一下,看看内存中变量的值就明白了。。。
acdbxzyw 2010-07-12
  • 打赏
  • 举报
回复
用JAVA的BigInteger做此ACM题。
笨笨周0915 2010-07-12
  • 打赏
  • 举报
回复
自己写个整数类。。。。可以处理超大数,再重载运算符。。。

64,652

社区成员

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

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