司徒阿宝 2022-11-16 16:09 采纳率: 100%
浏览 24
已结题

关于#泰勒级数计算sinx的值#的问题,如何解决?

求看一下哪里错了

img


#include <stdio.h>
#include <math.h>
double Fact(double n);
double pow_n(double x,double n);
void sinx(double x);

int main()
{
    double x;
    printf("Input x:\n");
    scanf("%lf",&x);
    sinx(x);
    return 0;
}

//计算sin
void sinx(double x) {
    int sign = -1;//正负号标识符
    int count=0;//用于计数
    double fraction,sinx=x;
    do{
        int i=1;
        i = i+2;
        sign = -sign;//正负号切换
        fraction = pow_n(x, i) / Fact(i);//计算每个分母
        fraction = fraction * sign;
        count++;  //计数
        sinx=sinx + fraction;
    }while(fabs(fraction) < 1e-5);
    printf("sin(x)=%.3f,count=%d\n", sinx, count);
}

//阶乘
double Fact(double n)
{
    int result = 1;
    for (int i = 1; i <= n; i++)
    {
        result = result * i;
    }
    return result;
}

////自定义pow函数x的n次幂
double pow_n(double x,double n)
{
    double m=1;
    if(n==0)
        return 1;
    else {
        for (int i = 1; i <= n; i++) {
            m = m * x;
        }
        return m;
    }
}
  • 写回答

1条回答 默认 最新

  • 快乐鹦鹉 2022-11-16 16:20
    关注

    int i=1;放到循环前面

    #include <stdio.h>
    #include <math.h>
    double Fact(double n);
    double pow_n(double x,double n);
    void sinx(double x);
    int main()
    {
        double x;
        printf("Input x:\n");
        scanf("%lf",&x);
        sinx(x);
        return 0;
    }
    //计算sin
    void sinx(double x) {
           int sign = 1;//正负号标识符
        int count=1;//用于计数
        double fraction,sinx=x;
                int i=1;
        do{
            count++;//计数
            i = i+2;
            sign = -sign;//正负号切换
            fraction = pow_n(x, i) / Fact(i);//计算每个分母
            fraction = fraction * sign;
            sinx=sinx + fraction;
        }while(fabs(fraction) >= 1e-5);
        printf("sin(x)=%.3f,count=%d\n", sinx, count);
    }
    //阶乘
    double Fact(double n)
    {
        double result = 1;
        for (int i = 1; i <= n; i++)
        {
            result = result * i;
        }
        return result;
    }
    ////自定义pow函数x的n次幂
    double pow_n(double x,double n)
    {
        double m=1;
        if(n==0)
            return 1;
        else {
            for (int i = 1; i <= n; i++) {
                m = m * x;
            }
            return m;
        }
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 11月24日
  • 已采纳回答 11月16日
  • 修改了问题 11月16日
  • 创建了问题 11月16日

悬赏问题

  • ¥15 Acrn IVSHMEM doorbell问题
  • ¥15 yolov5中的val测试集训练时数量变小问题
  • ¥15 MPLS/VPN实验中MPLS的配置问题
  • ¥15 materialstudio氢键计算问题
  • ¥15 已知隐函数其中一个变量的,求另外一个变量
  • ¥15 echarts图表制作
  • ¥15 halcon根据玻璃面板纹路取区域
  • ¥15 HFSS设计小型化180度耦合器
  • ¥15 使用CInternetSession,CHttpFile读取网页文件时有些电脑上会卡住怎么办?
  • ¥15 水下机器人的半物理仿真研究