题目链接:https://bzoj.org/p/P00554
Description
利用公式e=1+1/1!+1/2!+1/3!+...+1/n! ,求e的值,要求保留小数点后10位。
Input
输入只有一行,该行包含一个整数n(2≤n≤15),表示计算e时累加到1/n!
Output
输出只有一行,该行包含计算出来的e的值,要求打印小数点后10位。
Samples
输入数据 1
10
输出数据 1
2.7182818011
Limitation
1s, 1024KiB for each test case.
Sol:用一个double类型进行累加就可以了,但要注意每一次要用1.0/n!
.
代码:
#include<bits/stdc++.h>
using namespace std;
int main(){
int n;
cin>>n;
double e=1;
long long k=1;//表示0!
for(int i=1;i<=n;i++){
k*=i;
e+=1.0/k;
}
printf("%.10lf",e);
return 0;
}
创作不易,点个赞再走吧!
标签:10,int,double,小数点,long,累加,求出 From: https://www.cnblogs.com/Ace-29/p/18286743