FZU 1058 粗心的物理学家

Description

世界著名的物理学家Albert正在计算的值。不幸的是,由于这项工作十分枯燥无味,这位伟大的物理学家得到了错误的答案。由于这一错误,它制造的几颗原子弹失去了控制,射向了五座重要的城市和一片热带雨林……

现在你的任务是帮助这位物理学家纠正这一错误,从而拯救世界。对于给定的n (n≤5*10^6),计算代数式的值。

Input

输入数据由多组数据组成。每组数据一行,仅有一个整数,表示n的值。

Output

对于每组数据,输出代数式的值(小数点后保留12位有效数字)。

Sample Input

2

Sample Output

1.500000000000

奇葩的题,开longdouble可以过,double的话必须要反过来加

只能暴力,开数组要炸内存。

#include<cstdio>
#include<cmath>
#include<map>
#include<iomanip>
#include<iostream>
#include<string>
#include<queue>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=1e3+10;
long double x;
int n;

int main()
{
	while (~scanf("%d",&n)) 
	{
		x=0;
		for (int i=1;i<=n;i++)
		{
			x=x+(long double)1/i;
		}
		cout<<fixed<<setprecision(12)<<x<<endl;
	}
	return 0;
}


你可能感兴趣的:(FZU 1058 粗心的物理学家)