解码方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解码方法相关的知识,希望对你有一定的参考价值。

代码:

class Solution {
public:
/**
* @param s a string, encoded message
* @return an integer, the number of ways decoding
*/

int numDecodings(string& s) {
// Write your code here
int size = s.size();
if(size == 0)
return 0;

int *dp = new int[size];
dp[0] = 1*(s[0]!=‘0‘);
if(size >= 2)
{
string t = s.substr(0,2);
int n = atoi(t.c_str());
dp[1] = dp[0]*(s[1]!=‘0‘) + (n>0 && n<=26);

for(int i=2; i<size; i++)
{
string t = s.substr(i-1,2);
int n = atoi(t.c_str());
dp[i] = dp[i-1]*(s[i]!=‘0‘) + (n>=10 && n<=26)*dp[i-2];
}
}
return dp[size-1];
}
};

 截图:

技术分享

 































以上是关于解码方法的主要内容,如果未能解决你的问题,请参考以下文章

leetcode 91. Decode Ways 解码方法(中等)

91. 解码方法

LeetCode 91. 解码方法

leetcode 91. 解码方法

leetcode 91. 解码方法

leetcode-91-解码方法