SimpleMLXG 2020-03-08 12:13 采纳率: 0%
浏览 1276
已采纳

计算sinx 求大佬帮忙看看

计算sin(x)

描述
计算sin(x)=x-x^3/3!+x^5/5!-X^7/7!+......,直到最后一项的绝对值小于10-7时停止计算。其中-2Π<=x<=2Π,^表示次方,如x^3表示x的3次方。
输入
一个实数x,-2Π<=x<=2Π
输出
sin(x)的值
输入样例 1
3.142
输出样例 1
-0.000407347

  • 写回答

1条回答 默认 最新

  • threenewbee 2020-03-08 12:25
    关注
    #include<stdio.h>
    #include<math.h>
    
    double sin(double);
    double nResult(double,double);
    
    int main()
    {
        double x=0;
        scanf("%lf",&x);
        printf("sin(%lf)=%lf\n",x,sin(x));
        return 0;
    }
    
    double sin(double x)
    {
        //sin(x)=x-x^3/3!+x^5/5!-x^7/7!+……+(-1)(n^2n+1)/(2n+1)!+……
        int i=0;
        double result=0,n=0;
        while( fabs( n=nResult(x,2*++i-1) ) > 0e-7 )//绝对值大于10^-7次方就循环
            result+=(i%2==1)?n:-n;
        return result;
    }
    
    double nResult(double x,double n)
    {
        //(n^2n+1)/(2n+1)!也就是n/1*n/2*n/3*n/4*.....n/(2n+1)
        return n==1?x:nResult(x,n-1)*x/n;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!