集训队每日一题3.31--级数求和
说明
已知:Sn= 1+1/2+1/3+...+1/n。显然对于任意一个整数K,当n足够大的时候,Sn大于K。
现给出一个整数K(1<=k<=15),要求计算出一个最小的n,使得Sn>K。
输入格式
每个测试文件只包含一组测试数据,每组一个整数k(1<=k<=15)。
输出格式
对于每组输入数据,输出要求计算出的最小的n,使得Sn>K。
样例
输入数据 1
1
Copy
输出数据 1
2
代码如下:
#include<iostream>
#include<stdio.h>
using namespace std;
int main(){
int sum;
double ans=0;
scanf("%d",&sum);
for(int i=1;;i++){
ans+=1.0/i;
if(ans>sum){
printf("%d",i);
break;
}
}
return 0;
}