bigpigeon
V2EX  ›  LeetCode

关于 leetcode 的 70. Climbing Stairs 的问题

  •  
  •   bigpigeon · Sep 19, 2016 · 3850 views
    This topic created in 3525 days ago, the information mentioned may be changed or developed.

    我的做法是这样

    func climbStairs(n int) int {
    	sum := 0
    	for i, j := n, 0; i >= 0; i, j = i-2, j+1 {
    		sum += i*j + 1
    	}
    	return sum
    }
    

    我发现 m 个 1 和 n 个 2 组合总数等于 m*n+1

    但当我提交时却报错:

    Input:
    6
    Output:
    12
    Expected:
    13
    

    但我去验证发现确实应该是 12 个才对啊 楼梯数为 6 的爬法

    111111
    
    11112
    11121
    11211
    12111
    21111
    
    1122
    1212
    1221
    2121
    2211
    
    222
    

    难道我忽略什么了?

    8 replies    2016-09-19 21:17:21 +08:00
    bigpigeon
        1
    bigpigeon  
    OP
       Sep 19, 2016
    timekiller
        2
    timekiller  
       Sep 19, 2016 via iPhone   ❤️ 1
    2112
    theFool
        3
    theFool  
       Sep 19, 2016   ❤️ 1
    Fibonacci ?
    czheo
        4
    czheo  
       Sep 19, 2016   ❤️ 1
    hanzichi
        5
    hanzichi  
       Sep 19, 2016
    2112 。。。
    hanzichi
        6
    hanzichi  
       Sep 19, 2016   ❤️ 1
    m 个 1 和 n 个 2 组合总数等于 m*n+1 。。
    这怎么推出来的。。很明显是 C(n+m,n) 吧。。

    安利下我的题解 Repo => https://github.com/hanzichi/leetcode
    zhy0216
        7
    zhy0216  
       Sep 19, 2016   ❤️ 1
    2112 ...
    bigpigeon
        8
    bigpigeon  
    OP
       Sep 19, 2016
    @hanzichi
    确实粗心了,非常感谢
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1040 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 40ms · UTC 18:31 · PVG 02:31 · LAX 11:31 · JFK 14:31
    ♥ Do have faith in what you're doing.