问题
91. 解码方法
难度:中等
一条包含字母 A-Z
的消息通过以下方式进行了编码:
'A' -> 1
'B' -> 2
...
'Z' -> 26
给定一个只包含数字的非空字符串,请计算解码方法的总数。
示例 1:输入: "12"
输出: 2
解释: 它可以解码为 "AB"(1 2)或者 "L"(12)。
示例 2:
输入: "226"
输出: 3
解释: 它可以解码为 "BZ" (2 26), "VF" (22 6), 或者 "BBF" (2 2 6) 。
解答
时间复杂度:遍历一遍字符串,所以是O(n)。
空间复杂度:用了一个数组,所以是O(n),
int numDecodings(string s)
{
if (s[0]=='0') return 0;
vector dp(s.size()+1);
dp[0]=1; dp[1]=1; //dp[i]表示i位长度的子字符串,能解码的种类数。
for(int i=1; i< s.size(); ++i) //注意:因为要看当前位的前一位,所以从i=1开始
{
if (s[i]=='0')
{
if (s[i-1]=='1' || s[i-1]=='2') dp[i+1]=dp[i-1]; // ..20..
else return 0; // ..30..
}
else
{
if (s[i-1]=='1' || (s[i-1]=='2' && s[i]
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?