博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
91 Decode Ways
阅读量:6280 次
发布时间:2019-06-22

本文共 1087 字,大约阅读时间需要 3 分钟。

为什么我常常对做题产生恐惧,因为可能为了一个不算难的问题不知不觉绕进去,这显然是不值得的。这题就是如此。

还要注意,java && 的优先级高于||的优先级,而不是同级。

public int numDecodings(String s) {                 if (s.length() == 0 || s.charAt(0) == '0') return 0 ; //0开头直接无法解码        //s[i-1] has r1 decode ways , s[i-2] has r2 decode ways        int r1 = 1 ;        int r2 = 1 ;              for (int i = 1 ; i < s.length() ; i ++){            //这里是if, if, else,不是if, else if, else            if (s.charAt(i)== '0'){              r1 = 0;            }            //java && 的优先级高于||的优先级,而不是同级。            if (s.charAt(i-1) == '1' || s.charAt(i-1) == '2' &&  s.charAt(i)<='6'){                r1 = r1 + r2 ;                r2 = r1 - r2 ;            }            //新加入的一位>6            else {                r2 = r1 ;            }        }        return r1 ;    }复制代码

这代码我是抄https://discuss.leetcode.com/topic/2562/dp-solution-java-for-reference 这里的,代码是很短,总体思路我是懂,但是对于corner case的处理,感觉很玄,因为它在看似不知不觉间处理了很多的test case。

也许我该试着理解一下code ganker的代码,虽然很长。 http://blog.csdn.net/linhuanmars/article/details/24570759/

这题就先如此。

转载于:https://juejin.im/post/5a3131f2f265da43133d2621

你可能感兴趣的文章
python2.7 之centos7 安装 pip, Scrapy
查看>>
机智云开源框架初始化顺序
查看>>
Spark修炼之道(进阶篇)——Spark入门到精通:第五节 Spark编程模型(二)
查看>>
一线架构师实践指南:云时代下双活零切换的七大关键点
查看>>
ART世界探险(19) - 优化编译器的编译流程
查看>>
玩转Edas应用部署
查看>>
music-音符与常用记号
查看>>
sql操作命令
查看>>
zip 数据压缩
查看>>
Python爬虫学习系列教程
查看>>
【数据库优化专题】MySQL视图优化(二)
查看>>
【转载】每个程序员都应该学习使用Python或Ruby
查看>>
PHP高级编程之守护进程,实现优雅重启
查看>>
PHP字符编码转换类3
查看>>
rsync同步服务配置手记
查看>>
http缓存知识
查看>>
Go 时间交并集小工具
查看>>
iOS 多线程总结
查看>>
webpack是如何实现前端模块化的
查看>>
TCP的三次握手四次挥手
查看>>