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

计算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;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题