/*
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称: fibnacci.cpp
* 作 者:高古尊
* 完成日期:2013 年11 月25 日
* 版本号: v1.0
*
* 输入描述:
* 问题描述:泰勒公式是一个用函数在某点的信息描述其附近取值的公式。如果函数足够光滑的话,在已知函数在某一点的各阶导数值的情况之下,泰勒公式可以用这些导数值做系数构建一个多项式来近似函数在这一点的邻域中的值。
函数的麦克劳林展开是泰勒公式的特殊形式,即泰勒公式中“某一点”取0的情况。e^x的麦克劳林展开式是e^x=1+x+x^2/2!+......,据此求出多组e^x的值。
精度要求:最后一项大于1e-7
Input
输入一个整数N,代表输入数据的组数,后随N行,每行一个小数,分别代表一个x
Output
输出N行,分别代表各行x对应的ex的值。输出精确到小数点后第7位。
Sample Input
* 问题分析:
*/
#include <iostream>
#include <iomanip>
#include<cstdio>
#include <cmath>
using namespace std;
double taile(double x);
int main()
{
int n,i;
double y;
cin>>n;
for(i=0; i<n; i++)
{
int x;
cin>>x;
y=taile(x);
cout<<setiosflags(ios::fixed)<<setprecision(7)<<y<<endl;
}
return 0;
}
double taile(double x)
{
if(x==0)
return 1;
int i=0,t;
//y需赋初值,只需y>1e-7
double sum,y=1,f=0;
while(y>1e-7)
{
sum=1;
i++;
for(t=0; t<i; )
t++,sum*=t;
y=pow(x,i)/sum,f+=y;
}
return f+1;
}