感觉写的太复杂了,想把求阶乘函数封存起来,但是还没做,等吃完饭回来搞。

# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @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