Easy-题目18:70. Climbing Stairs

原创 2016年05月30日 20:01:17

题目原文:
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?
题目大意:
你在爬一个n阶的楼梯,每次可以上1阶也可以上2阶。有多少种不同的爬法?
题目分析:
设爬n阶的楼梯不同的方法是f(n),则最后一次可以爬1阶也可以爬2阶。因此f(n)=f(n-1)+f(n-2).这个公式很熟悉吧。。没错此题即是求斐波那契数列的n+1项。为什么是n+1项呢,因为斐波那契数列是1,1,2,3,….而爬楼梯问题的方法数是1,2,3,5…
源码:(language:c)

int climbStairs(int n) {
    int i,sum1=1,sum2=2,sum=0;
    if(n==1||n==2)
        return n;
    else {
        for(i=2;i<n;i++) {
            sum=sum1+sum2;
            sum1=sum2;
            sum2=sum;
        }
        return sum;
    }
}

成绩:
0ms,beats0.16% 众数0ms,99.84%.
Cmershen的碎碎念:
求斐波那契数列切勿用递推公式f(n)=f(n-1)+f(n-2),会引起超时。因为随着n的增加会大量出现重复计算,使用递推的算法复杂度是NP难的,而本算法是O(n)复杂度的。如果使用斐波那契的通项公式(什么?你不知道斐波那契可以求通项?回去复习高中数学一百遍!)算法复杂度可降低到O(1),但通项中的系数是无理数,在计算机中不易表示。
斐波那契数列通项公式如下:
这里写图片描述

版权声明:完整版Leetcode题解请出门左转https://github.com/cmershen1/leetcode/tree/master/docs

LeetCode(70) Climbing Stairs

题目You are climbing a stair case. It takes n steps to reach to the top.Each time you can either climb...
  • fly_yr
  • fly_yr
  • 2015年08月19日 21:54
  • 2788

70. Climbing Stairs [easy] (Python)

题目链接https://leetcode.com/problems/climbing-stairs/题目原文 You are climbing a stair case. It takes n s...
  • coder_orz
  • coder_orz
  • 2016年05月26日 13:10
  • 1525

LeetCode 70 Climbing Stairs(Python详解及实现)

【题目】 You are climbing a stair case. It takes nsteps to reach to the top.   Each time you can eith...
  • yangjingjing9
  • yangjingjing9
  • 2017年08月05日 12:56
  • 273

leetcode之70. Climbing Stairs(C++解法 动态规划思想)

原题: You are climbing a stair case. It takes n steps to reach to the top.Each time you can either cl...
  • haimianxiaodao
  • haimianxiaodao
  • 2016年09月21日 15:19
  • 354

LeetCode 70 — Climbing Stairs(C++ Java Python)

题目:http://oj.leetcode.com/problems/climbing-stairs/ You are climbing a stair case. It takes n steps...
  • dragon_dream
  • dragon_dream
  • 2014年03月20日 22:17
  • 2998

leetcode 70 Climbing Stairs

Climbing Stairs                       You are climbing a stair case. It takes n steps to reach t...
  • wangyaninglm
  • wangyaninglm
  • 2015年04月29日 17:46
  • 2817

leetcode 70.Climbing Stairs-爬楼梯|动态规划

You are climbing a stair case. It takes n steps to reach to the top. Each time you can either climb...
  • happyaaaaaaaaaaa
  • happyaaaaaaaaaaa
  • 2015年10月07日 13:00
  • 2289

(Java)LeetCode-70. Climbing Stairs

You are climbing a stair case. It takes n steps to reach to the top. Each time you can either cli...
  • u012848330
  • u012848330
  • 2016年11月06日 16:01
  • 197

lintcode climbing-stairs 爬楼梯 递归 循环

问题描述lintcode笔记爬n级楼梯的方法数,等于爬上n-1级楼梯的方法数(再爬1级),加上爬上n-2级楼梯的方法数(再爬2级)。climbStairs(n) = climbStairs(n-1) ...
  • waltonhuang
  • waltonhuang
  • 2016年07月26日 14:38
  • 461

LeetCode | 746. Min Cost Climbing Stairs | 简单DP上楼梯问题

746. Min Cost Climbing Stairs My SubmissionsBack to Contest ·       User Accepted:995 ·      ...
  • u012737193
  • u012737193
  • 2017年12月21日 19:51
  • 121
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Easy-题目18:70. Climbing Stairs
举报原因:
原因补充:

(最多只允许输入30个字)