首页 > 代码库 > 子序列的和

子序列的和

输入两个正整数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;}