leetcode91
class Solution {
public int numDecodings(String s) {
if(s.length()==0){
return 0;
}
int[] dp = new int[s.length()];
dp[0] = s.charAt(0)=='0'?0:1;
if(s.length()==1){
return dp[0];
}
int k = s.charAt(0) > '0' && s.charAt(1) > '0'? 1:0;
dp[1] = k + (s.charAt(0) == '1' || s.charAt(0) == '2' && s.charAt(1) <= '6' ? 1:0);
for (int i = 2; i < dp.length; i++) {
if(s.charAt(i)!='0'){
dp[i] += dp[i-1];
}
if(s.charAt(i-1)=='1'||s.charAt(i-1)=='2'&&s.charAt(i)<='6'){
dp[i] += dp[i-2];
}
}
return dp[s.length()-1];
}
}
补充一个python的实现:
class Solution:
def numDecodings(self, s: str) -> int:
n = len(s)
if n == :
return
dp = [ for x in range(n + )]
dp[] = #空白字符串,有1种表示方式,就是空白字符串
if <= int(s[]) and int(s[]) <= :#第一位是1~9之间的数
dp[] = #有一种表示方式 for i in range(, n + ):
pre1 = int(s[i-:i])#当前位置转化的数字
pre2 = int(s[i-:i])#前一位和当前位置组成的数字
if <= pre1 and pre1 <= :#当前数字是1~9之间的数
dp[i] += dp[i - ]
if <= pre2 and pre2 <= :#前一位和当前位置组成的数字是10~26之间的数
dp[i] += dp[i - ]
return dp[n]
参考:https://leetcode.com/problems/decode-ways/discuss/30529/Readable-Python-DP-Solution
本题关键在于第11行到15行之间的逻辑,更新dp[i]的规则。
dp[i]表示,前i个字符(从1开始计算)有几种解码方式。
如果当前字符s[i-1] 是[1,9]之间的数字,则把当前字符独立出来,可以在s[0]...s[i-2]这个子串的每一种表示方式后面,多一个A~I之间的单独的字母就可以完成。
因此其表示方式的数量与s[0]...s[i-2]的表示数量一样,只是对应每一种具体的组成时多了一个字母,即dp[i] += dp[i-1]。
入股当前字符和其前一位字符,可以组成一个数字是[10,26]之间的,则把这两个字符独立出来,可以在s[0]...s[i-3]这个字串的每一种表示方式后面,
多一个J~Z之间的单独的字母就可以完成。因此其表示方式的数量与s[0]...s[i-3]的表示数量一样,只是对应每一种具体的组成时多了一个字母,即dp[i] += dp[i-2]。
以'226'为例,这个字符串可以分成三种情况:
1、'2' '2' '6' -> B B F
2、'22' '6' -> V F
3、'2' '26' -> B Z
在i=2时,dp = [1,1,0,0],
第一步是判断s[1]字符,由于s[1]字符转化成数字是2,在1~9之间,因此'2'的解码数量与''的解码数量一样。
'' -> 'B' 是1种
'' + '2' ->'B' + 'B' 也是1种
第二步判断s[0]和s[1]组成的字符,由于这两个字符所组成的数字是22,在10~26之间,因此'22'的解码数量与''空白串的解码数量一样。
'' -> '' 是1种
'' + '22' -> '' + 'V' 也是1种
这两步判断加到一起,等于2,就是dp[2]的值。
在i=3时,dp[1,1,2,0]
第一步是判断s[2]字符,由于s[2]字符转化成数字是6,在1~9之间,因此'6'的解码数量与''的解码数量一样。
'22' -> 'BB' '22' -> 'V' 是2种
'22' + '6' -> 'BB' + 'F' '' + '6' -> 'V' + 'F' 也是2种
第二步是判断s[1]和s[2]组成的字符,由于这两个字符所组成的数字是26,在10~26之间,因此'226'的解码数量与'2'的解码数量一样。
'2' -> 'B' 是1种
'' + '26' -> 'B' + 'Z' 也是1种
这两步判断加到一起是2 + 1 等于3,就是dp[3]的值。
此时循环完毕,返回dp[3]即为所求。
leetcode91的更多相关文章
- [Swift]LeetCode91. 解码方法 | Decode Ways
A message containing letters from A-Z is being encoded to numbers using the following mapping: 'A' - ...
- 【leetcode-91 动态规划】 解码方法
一条包含字母 A-Z 的消息通过以下方式进行了编码: 'A' -> 1 'B' -> 2 ... 'Z' -> 26 给定一个只包含数字的非空字符串,请计算解码方法的总数. 示例 1 ...
- Leetcode91.Decode Ways解码方法
一条包含字母 A-Z 的消息通过以下方式进行了编码: 'A' -> 1 'B' -> 2 ... 'Z' -> 26 给定一个只包含数字的非空字符串,请计算解码方法的总数. 示例 1 ...
- LeetCode91 Decode Ways
题目: A message containing letters from A-Z is being encoded to numbers using the following mapping: ' ...
- 【算法题12 解码方法decode way】
1.来源LeetCode91 一条包含字母 A-Z 的消息通过以下方式进行了编码: 'A' -> 1 'B' -> 2 ... 'Z' -> 26 给定一个只包含数字的非空字符串,请 ...
随机推荐
- Cassandra 数据库, python cqlsh命令
★ cql操作数据库(cqlsh.bat: python cqlsh命令操作<优缺点:https://blog.csdn.net/vbirdbest/article/details/77662 ...
- JS校验 if (! temp_var) {} //拦截 ''和 undefined
if (! aaa) {} //拦截 ' ' 和 undefined 和 0 不拦截null
- vue组件独享守卫钩子函数参数详解(beforeRouteEnter、beforeRouteUpdate、beforeRouteLeave)
一样的和前面路由钩子类似的步骤 首先在demo下面的components下面新建一个test.vue组件 test组件代码 <template> <div class="t ...
- jsp页面九大内置对象
资源转载自网上,不可用于商用,学习可以.内置对象又叫隐式对象/隐含对象是由WEB容器加载的一组类的实例,不需要预先声明就可以在脚本代码和表达式中随意使用的对象. 这九大隐式对象可以按照期作用分类为: ...
- 表单添加缩略图及截图js代码
此为表单提交是上传截图的代码,待优化: // 添加小程序图片 function addAvatar(obj){ var file = obj.files[0]; limit($('.avatar_bo ...
- 【MVC】VS常用技巧
1,在VS2010中,选中指定的代码段,可以拖拽到工具箱中,形成标签,以后还想书写类似的代码,双击鼠标即可. 2,在VS2012中,可以在注释上标注//TODO:我是注释 这样,注释就会出现在任务列表 ...
- Centos7安装killall,fuser, killall,pstree和pstree.x11
centos7精简安装后,使用中发现没有killall命令. 经查找,可以通过以下命令解决: yum -y install psmisc 简单介绍一下 psmisc : Psmisc软件包包含三个帮助 ...
- bzoj4247挂饰——压缩的动态规划
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4247 1.dp之前要先按挂钩个数从大到小排序,不然挂钩一度用成负的也可能是正确的,不仅脚标难 ...
- POJ2392 Space Elevator
题目:http://poj.org/problem?id=2392 一定要先按高度限制由小到大排序! 不然就相当于指定了一个累加的顺序,在顺序中是不能做到“只放后面的不放前面的”这一点的! 数组是四十 ...
- JMeter--使用HTTP信息头管理器
使用HTTP信息头管理,可以帮助测试人员设定JMeter发送的HTTP请求头所包含的信息.HTTP信息头中包含有”User-Agent".“Pragma".”Referer&quo ...