洛谷 P1035级数求和题解--zhengjun
题目描述
已知:\(S_n= 1+1/2+1/3+…+1/n\)。显然对于任意一个整数 \(k\),当 \(n\) 足够大的时候,\(S_n>k\)。
现给出一个整数 \(k\),要求计算出一个最小的 \(n\),使得 \(S_n>k\)。
输入格式
一个正整数 \(k\)。
输出格式
一个正整数 \(n\)。
输入输出样例
输入 #1 复制
1
输出 #1 复制
2
说明/提示
【数据范围】
对于 \(100\%\) 的数据,\(1\le k \le 15\)。
思路
难得一道极水的模拟题
一个while就解决了
不多说,代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
	double sum=0;
	double n=0;
	int k;
	cin>>k;
	while(sum<=k)
	{
		n++;
		sum+=1.0/n;
	}
	cout<<n;
	return 0;
}
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号