输入两个正整数n<m<10^6,输出1/n^2 + 1/(n+1)^2 + …… + 1/m^2,保留5位小数。例如n=2,m=4时答案是0.42361;n=65536,m=655360时答案为0.00001。注意:本题有陷阱。

分析:for循环累加。本题陷阱在于n比较大时,n*n会溢出,所以 1/n^2 应该用 1/n/n 而不是 1/(n*n)。

源码:

#include<stdio.h>
int main()
{
    int n,m,i;
    double sum;
    while(~scanf("%d %d",&n,&m))
    {
        sum=0;
        for(i=n;i<=m;i++)
        {
            sum+=(double)1/i/i;
        }
        printf("%.5lf\n",sum);
    }
    return 0;
}
posted on 2014-07-17 13:48  lipching  阅读(202)  评论(1编辑  收藏  举报