python编写n的阶乘

python编写n的阶乘,第1张

一个整数的阶乘裂神竖就是所有小于等于该数字的正整数的积。举例说明3的阶乘就是3*2*1。

电脑:WIN10

软件:ISO

软件:python

1、用def代码创建肆大一个函数,名称为func,参数为n

def func(n):

2、创建一个变量res,赋值为函数的参数n,代码如下:

res = n。瞎升

3、然后写入for range循环,具体代码如下:

for i in range(1,n):

4、接下来在for循环当中进行计算并且返回res,具体代码如下:

res *= i

return res。

5、用print代码打印输出3的阶乘,代码如下:

print(func(3))。

6、以上代码实现了阶乘的运算,另外我们还可以用递归的方式进行。代码如下:

def func1(n):

if n==1:

return 1

else:

return n *func1(n-1)

print(func1(3))

递归方式是函数自己调用自己。

def little_than_50(x):

    if x <= 50:

        return True

  清袜棚  else:

        return False

def calculate_factorial(x):

    if x <= 1:

        return 1

    else:

        return x*calculate_factorial(x-1)

while True:

    n = int(input("Input a number for 好绝calculating factorial:"))

    if little_than_50(n):

        break

    else:

        print("{} is out of range,please input again!".format(n))

print("The factorial of {} is {}"答则.format(n, calculate_factorial(n)))

解法1

数组解法牛。

首先定义一个ns数组用来存储n!的各个位数上的数值,利用for循环给ns加入10000个0值,以方便后面直接根据index对数组进行 *** 作。

然后定义length作为 “数组的长度肢简”(有真实数值的而非自动添加的0) 也即n!的结果的位数。

之后也必须用到for循环进行累乘,但跟解法一的直接累乘不同,这里是乘数(即i)跟各个位上的数分别相乘,若结果大于等于10则carry>0即向前进一位数值为carry,若j循环结束后carry>0则说明需要在当前ns的“长度”上进一位,所以length+1即位数+1,这里carry起的就是判断是否进位的作用,而length则代表着结果的位数。

n= int(input())

ns = [0 for i in range(10000) ]

n= int(input())

ns = [0 for i in range(10000) ]

length = 1

ns[0] = length = 1

if n>=2:

#for i in range(2,n+1):

##carry = 0

##for j in range(length):

###temp = ns[j] * i + carry

###carry = int(temp/10)

###ns[j] = temp % 10

##while carry>0:

###ns[length] += carry%10

###length+=1

###carry = int(carry/10)

while length>0:

#length -=1

#print(ns[length],end='')

把# 替换为空格就可以运行。

如弯做输入1000,计算历闹裤1000!

解法2

print()

m=int(input("计算m!,请输入整数m:"))

import math

a=sum([math.log10(i) for i in range(1,m+1)])

b=int(a)

c=a-b

print(f'{m}!={10**c}*10^{b}')


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12256192.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-22
下一篇2023-05-22

发表评论

登录后才能评论

评论列表(0条)

    保存