题目:
利用sinx的麦克劳林展开公式,输入x并计算sinx的值,直到最后一项的绝对值小于时为止
要点:
(1)阶乘函数的构造
(2)循环控制结构的选择
(3)迭代方法的使用
(5)数学函数的调用
解决:
#include <stdio.h>
#include <math.h>
int Fact(int n)
{
int y = 1;
for (int i = 1; i <= n; i++)
{
y *= i;
}
return y;
}
int main()
{
double x = 0, a = 0, sinx = 0;
printf("please input x\n");
scanf_s("%lf", &x);
for (int i = 0; ; i++)
{
a = pow(-1, i) * pow(x, 2 * i + 1) / double(Fact(2 *i + 1));
if (fabs(a) < pow(10, -5))
{
break;
}
else
{
sinx += a;
}
}
printf("sinx=%f", sinx);
}
解析:
(1)迭代法构造阶乘函数Fact
(2)for()中的循环截止条件为了方便可以用if+break代替,这里也可以使用while更方便
while(fabs(a)>pow(10,-5))
{
a=pow(-1,i)*pow(x,2*i+1)/fact(2*i+1);
sinx+=a;
i++;
}
(3)sinx的计算可以拆成每个项迭代相加
(4)由题目很明显可知,要用到乘方pow()和取实数绝对值fabs()函数,不要用成了取整绝对值abs()