|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
7-15 求sin(x)近似值--2019秋考题 (15分)
用麦克劳林展开式求sin(x)近似值的多项式为:
maike.jpg
用户输入x和n,其中x为双精度类型实数,用户输入的n一定满足1<=n<=12。计算多项式的值,结果保留四位小数。
输入格式:
一个实数,跟上一个空格,再跟一个整数。
输出格式:
小数点后有四位小数
输入样例:
下面是计算30度正弦(PI/6=0.5236)的值。
0.5236 8
输出样例:
0.5000
//下面是我的代码
#include <stdio.h>
#include <math.h>
int main()
{
int n,T;
int i;
double x,sum=0.0;
float t;
float fenzi=1.0,fenmu=1.0;
scanf("%lf %d",&x,&n);
for(i=1;i<=n;i++)
{
fenzi = pow(x,(2*i-1));
fenmu *= (2*i-1);
T = -1;
t = -T * zi / mu;
sum += t;
}
printf("%.4lf",sum);
}
本帖最后由 风过无痕1989 于 2020-12-25 21:49 编辑
除其他小错误外,求阶乘错误,已修改,下面的程序正确:
- #include <stdio.h>
- #include <math.h>
- int main()
- {
- int n;
- int i, j;
- double x, sum = 0.0;
- double t;
- double fenzi = 1.0, fenmu = 1.0;
- scanf("%lf%d", &x, &n);
- for (i = 1;i <= n;i++)
- {
- fenzi = pow(x, (2 * i - 1));
- for (j = 1;j <= (2 * i - 1);j++) // 求阶乘
- {
- fenmu *= j;
- }
- if (i % 2 != 0)
- {
- t = fenzi / fenmu;
- }
- else
- {
- t = -1.0 * fenzi / fenmu;
- }
- sum += t;
- }
- printf("%.4lf", sum);
- }
复制代码
|
|