首页>>后端>>Python->python10000的阶乘有多少个0(2023年最新整理)

python10000的阶乘有多少个0(2023年最新整理)

时间:2023-12-12 本站 点击:0

导读:很多朋友问到关于python10000的阶乘有多少个0的相关问题,本文首席CTO笔记就来为大家做个详细解答,供大家参考,希望对大家有所帮助!一起来看看吧!

python怎么求阶乘

解法1

数组解法牛。

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

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

之后也必须用到for循环进行累乘,但跟解法一的直接累乘不同,这里是乘数(即i)跟各个位上的数分别相乘,若结果大于等于10则carry0即向前进一位数值为carry,若j循环结束后carry0则说明需要在当前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 carry0:

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

###length+=1

###carry = int(carry/10)

while length0:

#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}')

一万的阶乘(10000,)末尾有多少个零

1、数学方法:通过数学归纳法找规律和数学极限的思想得出它是一条斜率接近于1/4的斜线,0的个数为:(number-1)/4=count向下取整;count向下取整就是0的个数;例如7!有几个连续末尾0:(7-1)/4=1.5个,向下取整为1个;2、Java代码(C也差不多):很简单,上代码publicclasscalculate{publicstaticvoidmain(String[]args){//TODOAuto-generatedmethodstubintnumber=你输入的那个数,count=0;//能被5^n除过(余数大于等于1)说明number!末尾有0for(intn=1;Math.floor(number/(Math.pow(5,n)))=1;n++){count+=Math.floor(number/(Math.pow(5,n)));}System.out.println("末尾有"+count+"个零");}}

python求解一个数的阶乘有几个零

2x5末位会多个0,所以每乘以一个5的倍数,末位会增加一个0,25,则2个……

所以

def get_factorial_zeros(num):

    result = 0

    while num = 5:

        num = num // 5

        result += num

    return result

结语:以上就是首席CTO笔记为大家整理的关于python10000的阶乘有多少个0的相关内容解答汇总了,希望对您有所帮助!如果解决了您的问题欢迎分享给更多关注此问题的朋友喔~


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/Python/27994.html