徐小龙 发表于 2020-5-24 11:48:26

看看哪错了,可以运行,但是结果些许偏差

已知sinx的近似计算公式如下:

sin x = x - x3/3! + x5/5! - x7/7! + ... + (-1)**(n-1)*(x**(2n-1)/(2n-1)!)

其中x为弧度,n为正整数。编写程序根据用户输入的x和n的值,利用上述近似计算公式计算sinx的近似值,要求输出结果小数点后保留8位。

【样例说明】

输入x为0.5236,n为4,求得sinx近似计算公式的值为0.50000105,小数点后保留8位;同样,输入x为0.5236,n为50,求得sinx近似计算公式的值为0.50000106,小数点后保留8位。

def sin (x,n):
    sinx=0
    while n:
      sinx += ((-1)**(n-1)) * (x**(2*n-1) / jic(2*n-1))
      n-=1
    return sinx
def jic (m):
    if m==1 or m==0:
      return 1
    result=m*jic(m-1)
    return result
y=sin (0.5263,20)
print(y)

txxcat 发表于 2020-5-25 00:14:09

你的代码没错,但是题目是0.5236,算的是0.5263。

txxcat 发表于 2020-5-25 00:19:28

建议最后一句改成:
print('%.8f' % y)
更加符合题目要求。
页: [1]
查看完整版本: 看看哪错了,可以运行,但是结果些许偏差