题目描述
已知:Sn=1+1/2+1/3+…+1/n.显然对于任意一个整数 k,当 n 足够大的时候,Sn>k。
现给出一个整数 k,要求计算出一个最小的 n,使得Sn>k。
输入格式
一个正整数 k。
输出格式
一个正整数 n。
这道题的思路就是定义一个浮点数Sn,然后让n不断加1,当Sn>k时输出就可以了。
代码如下:
#include<bits/stdc++.h>
using namespace std;
int main(){
double k;
cin>>k;
double n=0,sn=0.00;
while(sn<=k){
n++;
sn+=1/n;
}
cout<<n;
return 0;
}
感谢大家的观看,我们下期再见!