65. Valid Number
题目:
Validate if a given string is numeric.
Some examples:"0"
=> true
" 0.1 "
=> true
"abc"
=> false
"1 a"
=> false
"2e10"
=> true
Note: It is intended for the problem statement to be ambiguous. You should gather all requirements up front before implementing one.
Update (2015-02-10):
The signature of the C++
function had been updated. If you still see your function signature accepts a const char *
argument, please click the reload button to reset your code definition.
链接: http://leetcode.com/problems/valid-number/
题解:
看到这种题目第一反应就是DFA了,不过怎么构建好的DFA真的很难。参考了leetcode讨论版。 Automata的知识还要好好学习学习,希望年底前还有时间。
首先对字符串进行trim,去除前后的space。之后构建DFA。输入有五种情况
- 0 - 9
- +, -
- e
- dot
- other
其中dot有种特殊情况, 就是 1.成立,但 .不成立,所以对有没有数字使用一个boolean变量来记录。 应该还可以再简化,要再研究研究。
Time Complexity - O(n), Space Complexity - O(1)。
public class Solution {
public boolean isNumber(String s) {
if(s == null || s.length() == 0)
return false;
s = s.trim();
int state = 0;
boolean hasNum = false; for(int i = 0; i < s.length(); i++) {
if(s.charAt(i) >= '0' && s.charAt(i) <= '9') {
hasNum = true;
if(state <= 2)
state = 2;
else
state = (state <= 5) ? 5 : 7;
} else if(s.charAt(i) == '+' || s.charAt(i) == '-') {
if(state == 0 || state == 3)
state++;
else
return false;
} else if (s.charAt(i) == '.') {
if(state <= 2)
state = 6;
else
return false;
} else if (s.charAt(i) == 'e') {
if(state == 2 || (hasNum && state == 6) || state == 7)
state = 3;
else
return false;
} else
return false;
} return (state == 2 || state == 5 || (hasNum && state == 6) || state == 7);
}
}
Test cases:
通过以下的例子我们可以看出,对dot我们需要额外判断,比如
"+.5e-5" - True
"+5." - True
"5e-10.6" - False 使用科学计数法以后不可以出现 dot
".5e10" - True
".e10" - False
"." - False
"+5.e10" - True
二刷:
还是用state machine,画图的方法。我们详细地分解一下每个步骤。
- 首先还是上面的图, 我们先对s进行trim操作,去除头尾的空格space
- 设置一个变量hasNum来判断在string中是否曾经出现过数字,这个对于判断state 6的dot很关键
- 从0开始遍历string,根据state machine写code,假设c为当前字符,我们考虑以下情况
- 当c为数字
- 当c为'+'或者'-'
- 当c为'.'
- 当c为'e', 这时要注意从s6到s3这条, 这里的条件为 state = s6 && hasNum,这样才可以进入s3
- 其他返回false
- 最后判断state是否在2, 5, 7以及 (state == 6 && hasNum)
Java:
Time Complexity - O(n),Space Complexity - O(1)
public class Solution {
public boolean isNumber(String s) {
if (s == null || s.length() == 0) {
return false;
}
s = s.trim();
int state = 0;
boolean hasNum = false;
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (c >= '0' && c <= '9') {
hasNum = true;
if (state <= 2) {
state = 2;
} else {
state = (state <= 5) ? 5 : 7;
}
} else if (c == '+' || c == '-') {
if (state == 0 || state == 3) {
state++;
} else {
return false;
}
} else if (c == '.') {
if (state <= 2) {
state = 6;
} else {
return false;
}
} else if (c == 'e') {
if (state == 2 || state == 7 || (state == 6 && hasNum)) {
state = 3;
} else {
return false;
}
} else {
return false;
}
}
return state == 2 || state == 5 || state == 7 || (state == 6 && hasNum);
}
}
三刷:
依然是画图使用state machine的方法。 上面的图有一个地方画错了, state 6的时候,不应该有一条自己连自己的链。需要找到一种更好的办法描述state 6的终止条件,和跳到state 3的条件。 state 6跳到state 3需要 hasNum + exp, 而终止时需要hasNum。
Java:
public class Solution {
public boolean isNumber(String s) {
if (s == null || s.length() == 0) return false;
s = s.trim();
int state = 0;
boolean hasNum = false;
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (Character.isDigit(c)) {
hasNum = true;
if (state <= 2) state = 2;
else if (state < 5) state = 5;
else if (state == 6) state = 7;
} else if (c == '.') {
if (state < 3) state = 6;
else return false;
} else if (c == 'e') {
if (state == 2 || (state == 6 && hasNum) || state == 7) state = 3;
else return false;
} else if (c == '+' || c == '-'){
if (state == 0 || state == 3) state++;
else return false;
} else {
return false;
}
} return state == 2 || state == 5 || state == 7 || (state == 6 && hasNum);
}
}
Reference:
http://postimg.org/image/n7lsslmgz
https://leetcode.com/discuss/13691/c-my-thought-with-dfa
https://leetcode.com/discuss/55915/lol-hard-to-understand-but-fast-8ms
https://leetcode.com/discuss/9013/a-simple-solution-in-cpp
https://leetcode.com/discuss/26682/clear-java-solution-with-ifs
https://leetcode.com/discuss/23447/a-clean-design-solution-by-using-design-pattern
https://leetcode.com/discuss/70510/a-simple-solution-in-python-based-on-dfa
https://leetcode.com/discuss/47396/ac-java-solution-with-clear-explanation
65. Valid Number的更多相关文章
- [leetcode]65. Valid Number 有效数值
Validate if a given string can be interpreted as a decimal number. Some examples:"0" => ...
- 【LeetCode】65. Valid Number
Difficulty: Hard More:[目录]LeetCode Java实现 Description Validate if a given string can be interpreted ...
- leetCode 65.Valid Number (有效数字)
Valid Number Validate if a given string is numeric. Some examples: "0" => true " ...
- [LeetCode] 65. Valid Number 验证数字
Validate if a given string can be interpreted as a decimal number. Some examples:"0" => ...
- Leetcode 65 Valid Number 字符串处理
由于老是更新简单题,我已经醉了,所以今天直接上一道通过率最低的题. 题意:判断字符串是否是一个合法的数字 定义有符号的数字是(n),无符号的数字是(un),有符号的兼容无符号的 合法的数字只有下列几种 ...
- LeetCode 65 Valid Number
(在队友怂恿下写了LeetCode上的一个水题) 传送门 Validate if a given string is numeric. Some examples: "0" =&g ...
- 【一天一道LeetCode】#65. Valid Number
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Validat ...
- 65. Valid Number 判断字符串是不是数字
[抄题]: Validate if a given string is numeric. Some examples:"0" => true" 0.1 " ...
- 65. Valid Number *HARD*
Validate if a given string is numeric. Some examples:"0" => true" 0.1 " => ...
随机推荐
- Python脚本控制的WebDriver 常用操作 <十九> 获取测试对象的状态
下面将使用webdriver来模拟测试中观察测试对象的状态的操作 测试用例场景 在web自动化测试中,我们需要获取测试对象的四种状态 是否显示.使用element.is_displayed()方法: ...
- (二)使用log4net写入数据库自定义日志
1.配置项目环境 1.1 本文只显示需要修改配置的操作,初次引入log4net环境的请参考上文. 1.2 安装mysql-connector-net.msi环境,下载地址.并手动生成数据库日志信息表. ...
- 如何取消FLEX里模态窗口的毛玻璃效果
在Flex里面,比如使用PopUpManager.createPopUp(this,TipWindow,false)第三个参数设成true 会出现毛玻璃效果让CPU飙升,可不可以改变模态窗口的效果,不 ...
- IEEE802是一个局域网标准系列
视频教程 http://v.youku.com/v_show/id_XNjgyODA0NzE2.html?from=s1.8-1-1.2 干线 总线+环形网的传递机制 环形令牌总线 802.4
- Java异常的深入研究与分析
前言 本文是异常内容的集大成者,力求全面,深入的异常知识研究与分析.本文由金丝燕网独家撰写,参考众多网上资源,经过内容辨别取舍,文字格式校验等步骤编辑而成,以飨读者.对于本文的内容,建议小白需要多多思 ...
- 注册微信小程序
注册微信小程序 小程序是一种新的开放能力,可以在微信内被便捷地获取和传播,同时具有出色的使用体验.开发者可以根据平台提供的能力,快速地开发一个小程序. 开放内容包括: 开放注册范围:企业.政府.媒体. ...
- Notes of the scrum meeting(11/1)
meeting time:9:00~10:30p.m.,November 1st,2013 meeting place:20号公寓楼前 attendees: 顾育豪 ...
- Valid format values for declare-styleable/attr tags[转]
http://chaosinmotion.com/blog/?p=179 reference string color dimension boolean integer float fraction ...
- bnuoj 33656 J. C.S.I.: P15(图形搜索题)
http://www.bnuoj.com/bnuoj/problem_show.php?pid=33656 [题解]:暴力搜索题 [code]: #include <iostream> # ...
- SHELL syntax error:unexpected end of file 提示错误
SHELL syntax error:unexpected end of file 提示错误 if [ -n "$1" ] then " else " fi e ...