感觉写的太复杂了,想把求阶乘函数封存起来,但是还没做,等吃完饭回来搞。
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
#
# @param number int整型
# @return int整型
#
class Solution:
def jumpFloor(self , number: int) -> int:
# write code here
#排列组合问题
#如果是偶数,则1个2级就是n-1种情况,2个2级就是Cn-2(2)种情况,n/2个2级就是1种情况
count = 1
if number%2 == 0:
for i in range(1,(number//2+1)): #i代表2级的数量
count1 = 1
count2 = 1
for j in range(0,i):
count1 *= (number-i-j) #A(n,k)
count2 *= (i-j) #阶乘
count += count1//count2
else :
for i in range(1,((number-1)//2+1)):
count1 = 1
count2 = 1
for j in range(0,i):
count1 *= (number-i-j) #A(n,k)
count2 *= (i-j) #阶乘
count += count1//count2
return count