真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

leetcode中如何解決爬樓梯問題

小編給大家分享一下leetcode中如何解決爬樓梯問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

龍文網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)建站于2013年創(chuàng)立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。

 

題目鏈接

https://leetcode-cn.com/problems/climbing-stairs/

 

題目描述

假設(shè)你正在爬樓梯。需要 n 階你才能到達樓頂。

每次你可以爬 12 個臺階。你有多少種不同的方法可以爬到樓頂呢?

注意:給定 n 是一個正整數(shù)。

示例 1:

輸入: 2
輸出: 2
解釋: 有兩種方法可以爬到樓頂。
1.  1 階 + 1 階
2.  2 階
 

示例 2:

輸入: 3
輸出: 3
解釋: 有三種方法可以爬到樓頂。
1.  1 階 + 1 階 + 1 階
2.  1 階 + 2 階
3.  2 階 + 1 階
   

解題方案

 

第一種思路

  • 標(biāo)簽:數(shù)學(xué)

  • 如果觀察數(shù)學(xué)規(guī)律,可知本題是斐波那契數(shù)列,那么用斐波那契數(shù)列的公式即可解決問題,公式如下:

leetcode中如何解決爬樓梯問題

  • 時間復(fù)雜度:O(logn)

 

第一種思路代碼

  • Java版本

class Solution {
   public int climbStairs(int n) {
       double sqrt_5 = Math.sqrt(5);
       double fib_n = Math.pow((1 + sqrt_5) / 2, n + 1) - Math.pow((1 - sqrt_5) / 2,n + 1);
       return (int)(fib_n / sqrt_5);
   }
}
 
  • JavaScript版本

/**
* @param {number} n
* @return {number}
*/
var climbStairs = function(n) {
   const sqrt_5 = Math.sqrt(5);
   const fib_n = Math.pow((1 + sqrt_5) / 2, n + 1) - Math.pow((1 - sqrt_5) / 2,n + 1);
   return Math.round(fib_n / sqrt_5);
};
   

第二種思路

  • 標(biāo)簽:動態(tài)規(guī)劃

  • 本問題其實常規(guī)解法可以分成多個子問題,爬第n階樓梯的方法數(shù)量,等于2部分之和

  1. 爬上n-1階樓梯的方法數(shù)量。因為再爬1階就能到第n階

  2. 爬上n-2階樓梯的方法數(shù)量,因為再爬2階就能到第n階

  • 所以我們得到公式dp[n] = dp[n-1] + dp[n-2]

  • 同時需要初始化dp[0]=1dp[1]=1

  • 時間復(fù)雜度:O(n)

 

第二種思路代碼

  • Java版本

class Solution {
   public int climbStairs(int n) {
       int[] dp = new int[n + 1];
       dp[0] = 1;
       dp[1] = 1;
       for(int i = 2; i <= n; i++) {
           dp[i] = dp[i - 1] + dp[i - 2];
       }
       return dp[n];
   }
}
 
  • JavaScript版本

/**
* @param {number} n
* @return {number}
*/
var climbStairs = function(n) {
   const dp = [];
   dp[0] = 1;
   dp[1] = 1;
   for(let i = 2; i <= n; i++) {
       dp[i] = dp[i - 1] + dp[i - 2];
   }
   return dp[n];
};
   

畫解

leetcode中如何解決爬樓梯問題leetcode中如何解決爬樓梯問題leetcode中如何解決爬樓梯問題

以上是“l(fā)eetcode中如何解決爬樓梯問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


本文標(biāo)題:leetcode中如何解決爬樓梯問題
標(biāo)題路徑:http://weahome.cn/article/jscgij.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部