用我目前学的只是,会严重溢出1我向高手请教!!谢谢!!
第1个回答 推荐于2016-01-09
定义为long double仍然会溢出,因为在32位系统下long double仍然只有32位,下面即可:
#include <stdio.h>
int n;
int r[600]={0};
int count(n)
{
int i;
for(i=0;i<600;i++)
r[i]*=n;
for(i=599;i>0;i--)
{
r[i-1]=r[i-1]+r[i]/10;
r[i]=r[i]%10;
}
}
int main()
{
int i;
int reach=0;
r[599]=1;
scanf("%d",&n);
for(i=1;i<=n;i++)
count(i);
for(i=0;i<600;i++)
{if(r[i]) reach=1;
if(r[i]||reach) printf("%d",r[i]);
}
getchar();
getchar();
}本回答被提问者采纳
#include <stdio.h>
int n;
int r[600]={0};
int count(n)
{
int i;
for(i=0;i<600;i++)
r[i]*=n;
for(i=599;i>0;i--)
{
r[i-1]=r[i-1]+r[i]/10;
r[i]=r[i]%10;
}
}
int main()
{
int i;
int reach=0;
r[599]=1;
scanf("%d",&n);
for(i=1;i<=n;i++)
count(i);
for(i=0;i<600;i++)
{if(r[i]) reach=1;
if(r[i]||reach) printf("%d",r[i]);
}
getchar();
getchar();
}本回答被提问者采纳
第2个回答 2008-12-15
可以考虑用字符串模拟乘法
第3个回答 2019-08-29
定义
为long
double仍然会溢出,因为在32位系统下long
double仍然只有32位,下面即可:
#include
<stdio.h>
int
n;
int
r[600]={0};
int
count(n)
{
int
i;
for(i=0;i<600;i++)
r[i]*=n;
for(i=599;i>0;i--)
{
r[i-1]=r[i-1]+r[i]/10;
r[i]=r[i]%10;
}
}
int
main()
{
int
i;
int
reach=0;
r[599]=1;
scanf("%d",&n);
for(i=1;i<=n;i++)
count(i);
for(i=0;i<600;i++)
{if(r[i])
reach=1;
if(r[i]||reach)
printf("%d",r[i]);
}
getchar();
getchar();
}
为long
double仍然会溢出,因为在32位系统下long
double仍然只有32位,下面即可:
#include
<stdio.h>
int
n;
int
r[600]={0};
int
count(n)
{
int
i;
for(i=0;i<600;i++)
r[i]*=n;
for(i=599;i>0;i--)
{
r[i-1]=r[i-1]+r[i]/10;
r[i]=r[i]%10;
}
}
int
main()
{
int
i;
int
reach=0;
r[599]=1;
scanf("%d",&n);
for(i=1;i<=n;i++)
count(i);
for(i=0;i<600;i++)
{if(r[i])
reach=1;
if(r[i]||reach)
printf("%d",r[i]);
}
getchar();
getchar();
}
第4个回答 2008-12-15
long double 是不会溢出的~~~ 不过精度可能不符合你的要求
第5个回答 2008-12-15
gfh