级数求和
测试数据来自 az0099/1001
Background
Special for beginners, ^_^
Description
已知:Sn=1+1/2+1/3+...+1/n。显然对于任意一个整数k,当n足够大的时候,Sn>k。现给出一个整数k,要求计算出一个最小的 n,使得Sn>k。
Format
Input
一个正整数k。
Output
一个正整数n。
Sample 1
Input
1
Output
2
Limitation
1s, 1024KiB for each test case.
Hint
C Code
#include<stdio.h>
int
main(){
int k,n;
double sn=0.0;
scanf("%d",&k);
for(n=1;;n++){
sn+=1.0/n;
if(sn>k*1.0)
break;
}
printf("%d",n);
return 0;
}
C++ Code
#include<cstdio>
using namespace std;
double search(double,double);
double n,t=1;
double print(double);
int main()
{
cin>>n;
search(n,0);//搜索模块。
}
double search(double x,double sum)//下面就是调用的深搜模块。
{
sum=sum+1/t;
t++;
if(sum>n) print(t);//调到输出的子程序
else return search(x,sum);//深搜
}
double print(double q)
{
cout<<q-1;
return 0;
}
#include<iostream>
#include<cstdio>
using namespace std;
double sum=0;
int main()
{
double n;
cin>>n;
for(double i=1;i<=1000000;++i)//要小心范围,小了是不可以的。
{
sum=sum+1/i;
if(sum>=n)
{
cout<<i;
return 0;
}
}
}
Python Code
b=1
s=0
a=input()
k=int(a)
while s <= k:
s+=1/b
b+=1
b-=1
print(b)
def Superposition(n):
sum = 1.0
return sum / n
def main():
k = input().split()
n = 0
sum = 0.0
while (sum <= float(k[0])):
n += 1
sum += Superposition(n)
print(n)
main()
信息
- ID
- 1000
- 难度
- 7
- 分类
- (无)
- 标签
- (无)
- 递交数
- 171
- 已通过
- 39
- 通过率
- 23%
- 上传者