鱼C论坛

 找回密码
 立即注册
查看: 1681|回复: 8

[已解决]求大佬帮帮我

[复制链接]
发表于 2020-12-25 20:31:47 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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);
}
最佳答案
2020-12-25 21:19:51
本帖最后由 风过无痕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);
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-12-25 21:19:51 | 显示全部楼层    本楼为最佳答案   
本帖最后由 风过无痕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);
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-25 21:26:33 | 显示全部楼层
程序已经可以正常运行了,只有我输出的是 0.4783,没有去查你的计算公式是否正确
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-25 21:51:08 | 显示全部楼层
查了一下麦克劳林公式,你求阶乘的方法错误。上面的程序已经修改完成,输出:0.4997
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-25 21:52:52 | 显示全部楼层
晕,你这不是求助帖子呀?难怪没有人来抢答
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-26 09:33:21 | 显示全部楼层
风过无痕1989 发表于 2020-12-25 21:19
除其他小错误外,求阶乘错误,已修改,下面的程序正确:

老师,您的代码输出是0.4997,而输出样例给的是0.5000,您能再看看您的的代码是哪里出错了吗,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-26 10:41:21 | 显示全部楼层
llf123456 发表于 2020-12-26 09:33
老师,您的代码输出是0.4997,而输出样例给的是0.5000,您能再看看您的的代码是哪里出错了吗,

这个误差是允许的,编译器不同,在运算时对最后一位的取舍也是不同的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-26 10:47:32 | 显示全部楼层
你能修改帖子,改为求助帖吗?这样就可以选择最佳答案了。
别人给了你帮助,你选他的答案为最佳答案,这就是你对帮你的人最好的报答了。如若不然,你的求助帖将会无人问津的
被选最佳答案后,无需你付出什么,只是系统会给获得最佳答案者奖励:鱼币+3,荣誉+2,贡献+1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-26 12:08:42 | 显示全部楼层
好的 ,抱歉
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-10 17:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表