|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 llf123456 于 2020-12-26 10:34 编辑
用麦克劳林展开式求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;
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);
}/为什么这段代码不能输出正确的输出样例呀
- #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);
- }
复制代码
|
|