2 u010178118 u010178118 于 2014.05.10 12:43 提问

n到m的平方分之一的和

输入两个正整数n<m<1000000,输出1/(n*n)+1/((n+1)*(n+1))+...+1/(m*m)
保留五位小数,注意:本题有数据陷阱。
输入要求:输入两个正整数n,m,用空格隔开
输出要求:保留五位小数
如: 2 4
0.42361

很简单的一个程序就是提交不过我的代码如下

#include
int main()
{
int n,m;
double sum=0.0;
scanf("%d%d",&n,&m);
if(n0)
{
for(int i=n;i<=m;i++)
{
sum+=1.0/(i*i);

}

printf("%.5lf\n",sum);

}

return 0;
}
输出结果也对,有什么数据陷进吗?为什么不对呢?

2个回答

zwwtj2014
zwwtj2014   2014.05.10 14:31

你输入m=999999试试,这是因为m*m超过了你的整数的存储范围

lym753024200
lym753024200   2014.05.10 16:59

先把分子1扩大些再累加求和,最后除回来就行了,免得下溢了

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!