编写一个计算sin(x)的函数,在主函数中输入x,调用sin(x)函数计算并输出y值。
y=sin(x)=x/1-x^3/3!+x^5/5!-x^7/7!+…(-1)^(n+1)*x^(2n-1)/(2n-1)!
首先,我们需要了解sin函数的计算方法。根据题目所给的公式,sin(x)可以表示为一个无穷级数。我们可以通过不断地加上级数的每一项来逼近sin(x)的值,直到最后一项的绝对值小于0.00001。
以下是C++代码示例:
#include<iostream>
#include<cmath>
using namespace std;
double sin(double x){
double sinx = 0.0;
int i=1;
double term=x;
while(fabs(term)>=0.00001){
sinx+=term;
i++;
term = (-1)*term *x*x/((2*i-1)*(2*i-2));
}
return sinx;
}
int main(){
double x,y;
cin>>x;
y=sin(x);
cout<<y<<endl;
return 0;
}
在这个代码中,我们使用了while循环来不断地加上级数的每一项,直到最后一项的绝对值小于0.00001。在每一次循环中,我们使用了一个变量term来表示每一项的值,并将其加到sinx中。同时,我们使用了一个变量i来表示当前项的序号。在每一次循环中,我们根据公式计算出下一项的值,并更新term的值。当最后一项的绝对值小于0.00001时,循环结束,我们得到了sin(x)的近似值。