开发者社区> 问答> 正文

输入n 计算n的阶乘,要用递归算法,python,谢谢大神!

输入n 计算n的阶乘,要用递归算法,python,谢谢大神!

展开
收起
知与谁同 2018-07-15 19:19:24 3940 0
3 条回答
写回答
取消 提交回答
  • def factorial(n):

    """
    :param n: 输入正整数
    :return: 返回阶乘结果
    """
    if not isinstance(n,int):
        return -1
    if n<=0:
        return -1
    
    result=n
    for i in range(1,n):
        result*=i
    return result

    一定要注意对函数边界的检查

    2019-07-17 22:55:03
    赞同 展开评论 打赏
  • 杀人者,打虎武松也。
    def factorial(num):#num=3
    """
    使用递归法求阶乘
    """
    sum = 0
    while num > 0:
    if num > 1:
    sum+=num*factorial(num-1)
    num-=1
    return sum
    else:
    return 1
    # pass
    num = int(input("请输入想要求的阶乘:\n"))
    result = factorial(num)

    print("result=%d"%result)
    2019-07-17 22:55:03
    赞同 展开评论 打赏
  • def fact(n):
    if n==0:
    return 1
    else:
    return n*fact(n-1)

    n=int(input())
    print(fact(n))
    2019-07-17 22:55:03
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
数据+算法定义新世界 立即下载
袋鼠云基于实时计算的反黄牛算法 立即下载
Alink:基于Apache Flink的算法平台 立即下载