5个回答
展开全部
定义为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();
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
可以考虑用字符串模拟乘法
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
定义
为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();
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
long double 是不会溢出的~~~ 不过精度可能不符合你的要求
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
gfh
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询