[关闭]
@inkysakura 2017-05-05T10:48:48.000000Z 字数 391 阅读 1283

lightoj1038

CODE


#include <iostream>
#include <iomanip>
using namespace std;
double dp[100005];
int ncase;
int cnt;
int main()
{
        int t;
        cin >> t;
        dp[1]=0;
        for(int i=2;i<=100000;i++)
        {
                double sum=0;
                int num=0;
                for(int j=1;j*j<=i;j++)
                {
                        if(i%j==0)
                        {
                                num++;
                                sum+=dp[j];
                                if(i/j!=j)
                                {
                                        num++;
                                        sum+=dp[i/j];
                                }
                        }
                }
                sum+=num;
                sum/=num-1;
                dp[i]=sum;
        }
        while(t--)
        {
                int n;
                cin >> n;
                cout <<fixed<<setprecision(10)<<"Case "<<++ncase<<": "<<dp[n]<<endl;
        }
        return 0;
}
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注