风轻云


私信TA

用户名:dotcpp0678895

访问量:970

签 名:

等  级
排  名 1532
经  验 2726
参赛次数 0
文章发表 25
年  龄 0
在职情况 学生
学  校 广西农业职业技术大学
专  业

  自我简介:

23级带专生

解题思路:

注意事项: 题目中并未明确表示两个参数是一行输入还是两行输出,看输入例子是一行输入,但实际是随机的,所以不管你是分一行输入还是两行输入都会错一半,解决方法是判断一下第一行所输入参数的长度。


参考代码:

def factorial(n):    # 阶乘运算
    if n == 0 or n == 1:  # 0和1的阶乘是1
        return 1
    else:
        return n * factorial(n - 1)  # 递归求阶乘


def get_pow(x, n):    # 自定义幂运算函数
    result_pow = 1
    for i in range(n):
        result_pow *= x
    return result_pow

# 判断是一行输入两个参数还是一行输入两个参数
list_all = list( map(eval, input().split()))
if len(list_all) == 1:
    x = list_all[0]
    n = eval(input())
else:
    x = list_all[0]
    n = list_all[1]
    

Sum = 0
for i in range(1, n + 1):
    Sum += get_pow(-1, i - 1) * get_pow(x, i) / factorial(i)    # 套问题中的公式
print(f"{Sum:.4f}")    # 保留四位小数输出


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区