题目描述:
已知字母 A-Z 可以表示成数字 1-26 。给定一个数字串,求有多少种不同的字符串等价于这个数字串。
题意分析:
代码:
class Solution {
public:
int numDecodings(string s) {
int n = s.size();
vector<int> dp(n+1,0);
dp[0] = 1;
for(int i=1;i<=n;++i)
{
if(s[i-1]!='0')
{
dp[i]+=dp[i-1];
}
if(i > 1 && s[i - 2] != '0' && ((s[i - 2] - '0') * 10 + (s[i - 1] - '0') <= 26))
{
dp[i]+=dp[i-2];
}
}
return dp[n];
}
};