独一无二的路

从前有一只小小的机器人叫小器,小器站在一个M*N的格子地板的最左上角,很孤单,世界辣么大,它也想去看看,经过不懈的努力它终于可以(只能)向下或者向右移动啦,它有一个宏伟的愿望就是要穿过格子地板到达右下角的砖,所以如果小器告诉你M和N,你能不能帮它计算一下这中间可以有多少条独一无二的路径?
这里写图片描述
注意:这是一道OJ题目,请用两个input(“”)分别获得M和N的值。
测试用例:
输入:
3
3
输出:
6

输入:
1
1
输出:
1

解析:
这里写图片描述
如上图,从出发点即蓝色点走到终点即红色点需要向右走 m1 m − 1 个格子,向下走 n1 n − 1 个格子,总共必须要走 m+n2 m + n − 2 个格子,所以总共的走法即是在 m+n2 m + n − 2 中选出 m1 m − 1 个向右走的格子或 n1 n − 1 个向下走的格子,用组合公式描述即 Cm1m+n2 C m + n − 2 m − 1 Cn1m+n2 C m + n − 2 n − 1 , 又已知 Cnm=m!n!(mn)! C m n = m ! n ! ( m − n ) ! ,故上述公式展开即为 Cm1m+n2=Cn1m+n2=(m1+n1)!(m1)!(n1)! C m + n − 2 m − 1 = C m + n − 2 n − 1 = ( m − 1 + n − 1 ) ! ( m − 1 ) ! ( n − 1 ) ! .

in_num1 = int(input(""))-1
in_num2 = int(input(""))-1
import math
num1 = math.factorial(in_num1+in_num2)
num2 = math.factorial(in_num1)
num3 = math.factorial(in_num2)
Num = int(num1//(num2*num3))
print(Num)

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值