免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1982 | 回复: 3
打印 上一主题 下一主题

求大神挑错。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-06-30 11:54 |只看该作者 |倒序浏览
     leetcode上的一道题:
     
You are climbing a stair case. It takes n steps to reach to the top.
Each time you can either climb 1 or 2 steps. In how many distinct ways can you climb to the top?

     我想用python写一段用排列组合求解的程序:

     class Solution:
    # @param {integer} n
    # @return {integer}
    def climbStairs(self, n):
        %%定义f(x)为求n的阶乘函数。
        def f(n):
          c=1
          for i in range(n+1):
             c*=i
          return c
        if n==1:
            return 1
        elif n==2:
            return 2
        elif n%2==0:
            sum=1
            for i in range(1,n/2+1):
                sum=sum+f(n-i)/(f(i)*f(n-i-i))
            return sum
        else:
            sum=1
            for i in range(1,(n+1)/2):
                sum=sum+f(n-i)/(f(i)*f(n-i-i))     %(line 22)
            return sum

但是网站返回这个错误:
     Runtime Error Message:
      Line 22: ZeroDivisionError: integer division or modulo by zero  
      Last executed input:3

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
2 [报告]
发表于 2015-07-02 16:47 |只看该作者
回复 1# yxycsgs


python太博大精深了.
代码看了一下没看明白
下面是一个方法

  1. def goto(n):
  2.     if not n: return 0
  3.     last, this = 0, 1
  4.     while n > 0:
  5.         last, this = this, this + last
  6.         n -= 1
  7.     print this

  8. goto(5)    # 8
复制代码
8个
01011
01101
01111
10101
10111
11011
11101
11111

论坛徽章:
4
白羊座
日期:2013-11-05 10:26:09冥斗士
日期:2015-11-17 14:19:55白银圣斗士
日期:2015-11-17 15:13:0815-16赛季CBA联赛之新疆
日期:2016-04-01 09:10:58
3 [报告]
发表于 2015-07-03 09:12 |只看该作者
回复 1# yxycsgs
主要的错误原因在这行:
  1. for i in range(n+1):
复制代码
因为range默认的开始数字是0,所以,不管使用什么数(>2),乘积一直是0
修改方法如下:
  1. for i in range(1, n+1):
复制代码
通过指定开始的数字,防止出现0进入乘法的过程.

论坛徽章:
0
4 [报告]
发表于 2015-07-05 16:38 |只看该作者
回复 3# icymirror


       谢谢,真的是这儿出问题了!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP