欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)LeetCode(91.解碼方法)

 更新時間:2021年07月19日 10:40:58   作者:Grandyang  
這篇文章主要介紹了C++實現(xiàn)LeetCode(91.解碼方法),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下

[LeetCode] 91. Decode Ways 解碼方法

A message containing letters from A-Z is being encoded to numbers using the following mapping:

'A' -> 1
'B' -> 2
...
'Z' -> 26

Given a non-empty string containing only digits, determine the total number of ways to decode it.

Example 1:

Input: "12"
Output: 2
Explanation: It could be decoded as "AB" (1 2) or "L" (12).

Example 2:

Input: "226"
Output: 3
Explanation: It could be decoded as "BZ" (2 26), "VF" (22 6), or "BBF" (2 2 6).

這道題要求解碼方法,跟之前那道 Climbing Stairs 非常的相似,但是還有一些其他的限制條件,比如說一位數(shù)時不能為0,兩位數(shù)不能大于 26,其十位上的數(shù)也不能為0,除去這些限制條件,跟爬梯子基本沒啥區(qū)別,也勉強算特殊的斐波那契數(shù)列,當然需要用動態(tài)規(guī)劃 Dynamci Programming 來解。建立一維 dp 數(shù)組,其中 dp[i] 表示s中前i個字符組成的子串的解碼方法的個數(shù),長度比輸入數(shù)組長多多1,并將 dp[0] 初始化為1?,F(xiàn)在來找狀態(tài)轉移方程,dp[i] 的值跟之前的狀態(tài)有著千絲萬縷的聯(lián)系,就拿題目中的例子2來分析吧,當 i=1 時,對應s中的字符是 s[0]='2',只有一種拆分方法,就是2,注意 s[0] 一定不能為0,這樣的話無法拆分。當 i=2 時,對應s中的字符是 s[1]='2',由于 s[1] 不為0,那么其可以被單獨拆分出來,就可以在之前 dp[i-1] 的每種情況下都加上一個單獨的2,這樣 dp[i] 至少可以有跟 dp[i-1] 一樣多的拆分情況,接下來還要看其能否跟前一個數(shù)字拼起來,若拼起來的兩位數(shù)小于等于26,并且大于等于 10(因為兩位數(shù)的高位不能是0),那么就可以在之前 dp[i-2] 的每種情況下都加上這個二位數(shù),所以最終 dp[i] = dp[i-1] + dp[i-2],是不是發(fā)現(xiàn)跟斐波那契數(shù)列的性質吻合了。所以0是個很特殊的存在,若當前位置是0,則一定無法單獨拆分出來,即不能加上 dp[i-1],就只能看否跟前一個數(shù)字組成大于等于 10 且小于等于 26 的數(shù),能的話可以加上 dp[i-2],否則就只能保持為0了。具體的操作步驟是,在遍歷的過程中,對每個數(shù)字首先判斷其是否為0,若是則將 dp[i] 賦為0,若不是,賦上 dp[i-1] 的值,然后看數(shù)組前一位是否存在,如果存在且滿足前一位是1,或者和當前位一起組成的兩位數(shù)不大于 26,則當前 dp[i] 值加上 dp[i - 2]。最終返回 dp 數(shù)組的最后一個值即可,代碼如下:

C++ 解法一:

class Solution {
public:
    int numDecodings(string s) {
        if (s.empty() || s[0] == '0') return 0;
        vector<int> dp(s.size() + 1, 0);
        dp[0] = 1;
        for (int i = 1; i < dp.size(); ++i) {
            dp[i] = (s[i - 1] == '0') ? 0 : dp[i - 1];
            if (i > 1 && (s[i - 2] == '1' || (s[i - 2] == '2' && s[i - 1] <= '6'))) {
                dp[i] += dp[i - 2];
            }
        }
        return dp.back();
    }
};

Java 解法一:

class Solution {
    public int numDecodings(String s) {
        if (s.isEmpty() || s.charAt(0) == '0') return 0;
        int[] dp = new int[s.length() + 1];
        dp[0] = 1;
        for (int i = 1; i < dp.length; ++i) {
            dp[i] = (s.charAt(i - 1) == '0') ? 0 : dp[i - 1];
            if (i > 1 && (s.charAt(i - 2) == '1' || (s.charAt(i - 2) == '2' && s.charAt(i - 1) <= '6'))) {
                dp[i] += dp[i - 2];
            }
        }
        return dp[s.length()];
    }
}

下面這種方法跟上面的方法的思路一樣,只是寫法略有不同:

C++ 解法二:

class Solution {
public:
    int numDecodings(string s) {
        if (s.empty() || s[0] == '0') return 0;
        vector<int> dp(s.size() + 1, 0);
        dp[0] = 1;
        for (int i = 1; i < dp.size(); ++i) {
            if (s[i - 1] != '0') dp[i] += dp[i - 1];
            if (i >= 2 && s.substr(i - 2, 2) <= "26" && s.substr(i - 2, 2) >= "10") {
                dp[i] += dp[i - 2];
            }
        }
        return dp.back();
    }
};

Java  解法二:

class Solution {
    public int numDecodings(String s) {
        if (s.isEmpty() || s.charAt(0) == '0') return 0;
        int[] dp = new int[s.length() + 1];
        dp[0] = 1;
        for (int i = 1; i < dp.length; ++i) {
            if (s.charAt(i - 1) != '0') dp[i] += dp[i - 1];
            if (i >= 2 && (s.substring(i - 2, i).compareTo("10") >= 0 && s.substring(i - 2, i).compareTo("26") <= 0)) {
                dp[i] += dp[i - 2];
            }
        }
        return dp[s.length()];
    }
}

我們再來看一種空間復雜度為 O(1) 的解法,用兩個變量 a, b 來分別表示 s[i-1] 和 s[i-2] 的解碼方法,然后從 i=1 開始遍歷,也就是字符串的第二個字符,判斷如果當前字符為 '0',說明當前字符不能單獨拆分出來,只能和前一個字符一起,先將 a 賦為0,然后看前面的字符,如果前面的字符是1或者2時,就可以更新 a = a + b,然后 b = a - b,其實 b 賦值為之前的 a,如果不滿足這些條件的話,那么 b = a,參見代碼如下:

C++ 解法三:

class Solution {
public:
    int numDecodings(string s) {
        if (s.empty() || s[0] == '0') return 0;
        int a = 1, b = 1, n = s.size();
        for (int i = 1; i < n; ++i) {
            if (s[i] == '0') a = 0;
            if (s[i - 1] == '1' || (s[i - 1] == '2' && s[i] <= '6')) {
                a = a + b;
                b = a - b;
            } else {
                b = a;
            }
        }
        return a;
    }
};

Java 解法三:

class Solution {
    public int numDecodings(String s) {
        if (s.isEmpty() || s.charAt(0) == '0') return 0;
        int a = 1, b = 1, n = s.length();
        for (int i = 1; i < n; ++i) {
            if (s.charAt(i) == '0') a = 0;
            if (s.charAt(i - 1) == '1' || (s.charAt(i - 1) == '2' && s.charAt(i) <= '6')) {
                a = a + b;
                b = a - b;
            } else {
                b = a;
            }
        }
        return a;
    }
}

到此這篇關于C++實現(xiàn)LeetCode(91.解碼方法)的文章就介紹到這了,更多相關C++實現(xiàn)解碼方法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C++結構體初始化的10種寫法總結

    C++結構體初始化的10種寫法總結

    這篇文章主要為大家詳細介紹了10種C++中結構體初始化的寫法,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-04-04
  • C語言數(shù)組實現(xiàn)三子棋應用實例

    C語言數(shù)組實現(xiàn)三子棋應用實例

    這篇文章主要為大家詳細介紹了C語言數(shù)組實現(xiàn)三子棋應用實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C++輸入輸出重定向方法示例

    C++輸入輸出重定向方法示例

    這篇文章主要給大家介紹了關于C++輸入輸出重定向的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-09-09
  • 基于C語言實現(xiàn)五子棋游戲完整實例代碼

    基于C語言實現(xiàn)五子棋游戲完整實例代碼

    這篇文章主要介紹了基于C語言實現(xiàn)五子棋游戲完整實例代碼,相信對于學習游戲開發(fā)的朋友會有一定的幫助與借鑒價值,需要的朋友可以參考下
    2014-08-08
  • C++算法之在無序數(shù)組中選擇第k小個數(shù)的實現(xiàn)方法

    C++算法之在無序數(shù)組中選擇第k小個數(shù)的實現(xiàn)方法

    這篇文章主要介紹了C++算法之在無序數(shù)組中選擇第k小個數(shù)的實現(xiàn)方法,涉及C++數(shù)組的遍歷、判斷、運算等相關操作技巧,需要的朋友可以參考下
    2017-03-03
  • 探究一下C語言生成隨機數(shù)的奧秘

    探究一下C語言生成隨機數(shù)的奧秘

    C語言中生成隨機數(shù)是一項非常重要的功能,因為許多現(xiàn)代應用程序需要使用隨機數(shù)。本文就來帶大家一起探究一下C語言生成隨機數(shù)的奧秘吧
    2023-03-03
  • C++多線程編程簡單實例

    C++多線程編程簡單實例

    本文給大家分享的是C++多線程編程簡單實例,由于C++本身沒有多線程機制,在windows下我們使用調用SDK win32 api來實現(xiàn),示例都很簡單,講解的也很詳細,推薦給大家。
    2015-03-03
  • C語言數(shù)據(jù)結構單鏈表接口函數(shù)全面講解教程

    C語言數(shù)據(jù)結構單鏈表接口函數(shù)全面講解教程

    這篇文章主要為大家介紹了C語言數(shù)據(jù)結構單鏈表所有接口函數(shù)的全面講解教程,有需要朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2021-10-10
  • C語言中函數(shù)與指針的應用總結

    C語言中函數(shù)與指針的應用總結

    本篇文章是對C語言中函數(shù)與指針的應用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++中的結構體vector排序問題

    C++中的結構體vector排序問題

    這篇文章主要介紹了C++中的結構體vector排序問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11

最新評論