题目:

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.

代码:

class Solution {
public:
bool isNumber(string s) {
if ( s.size()< ) return false;
// escape space from begining and end
int index_begin = ;
int index_end = s.size()-;
while ( s[index_begin]==' ' && index_begin<s.size() ) ++index_begin;
while ( s[index_end]==' ' && index_end>= ) --index_end;
// digit, dot, sign, exp
enum PreChar{ NONPRE, DIGIT, SIGN, EXP, DOT };
enum PreChar preChar = NONPRE;
bool hasDigit = false, hasSign = false, hasExp = false, hasDot = false;
int index = index_begin;
for ( ;index <= index_end; ++index )
{
// space
if ( s[index]==' ') return false;
// digit
if ( s[index]>='' && s[index]<='' ) { hasDigit = true; preChar = DIGIT; continue; }
// sign
if ( s[index]=='+' || s[index]=='-' ){
if ( preChar==EXP || preChar==NONPRE ) { preChar = SIGN; hasSign = true; continue; }
else { return false; }
}
// exp
if ( s[index]=='e' || s[index]=='E' ){
if ( (preChar==DIGIT || preChar==DOT) && !hasExp && hasDigit ) { preChar = EXP; hasExp = true; continue; }
else { return false; }
}
// dot
if ( s[index]=='.' ){
if ( !hasExp && !hasDot && (preChar==DIGIT || preChar==SIGN || preChar==NONPRE ) ) { preChar = DOT; hasDot = true; continue; }
else { return false; }
}
// illegal input char
return false;
}
// end with digit or dot
return preChar==DIGIT || (preChar==DOT && hasDigit);
}
};

tips:

主要基于这篇blog的思路(http://blog.unieagle.net/2012/11/06/leetcode题目:valid-number/)。在其基础上,对逻辑进行了更系统的梳理和简化。

思路如下:

1. 首先排除字符串首尾的space,这样可以简化判断逻辑(只要在后面的字符串中再出现空格,就一定不是合法数字)

2. 判断剩余的字符串中出现dot('.'), sign('+','-'), exp('e','E'), digit(0~9)是否是合法的。判断的核心逻辑有两个:

  a. 上一个出现的字符是什么(即代码中的preChar)

  b. dot,sign,exp,digit,是否在之前出现过

这种代码逻辑的好处是:只要认准了两个核心判断逻辑,在这两个核心逻辑之内修修补补,就可以不断地刷test case直到AC。

如果以后有类似的问题,状态条件非常多的,但是输入条件相对固定;并且又需要根据序列化输入条件判断的。

可以多设定几类变量逻辑变量,然后通过判断几类逻辑变量的取值来往下进行;即使不能一次bug free,但是总可以把逻辑补完全。

=====================================================

之前一直看网上的有限状态机(FSM)的做法(http://www.cnblogs.com/chasuner/p/validNumber.html),这种思路的代码非常consice。

FSM怎么运转的,解释的很清晰;但是FSM中这0~8的状态是怎么来的,我并没有看懂,所以只好选择比较一般的方法。

================================================

第二次过这道题,直接照着上次写的代码记忆重复了一下。

class Solution {
public:
bool isNumber(string s) {
if ( s.size()< ) return false;
// remove blanks both begin and end
int i_begin = ;
int i_end = s.size()-;
while ( s[i_begin]==' ' && i_begin<i_end ) ++i_begin;
while ( s[i_end]==' ' && i_begin<i_end ) --i_end;
enum PreType{ NONE, DIGIT, EXP, SIGN, DOT };
enum PreType preType = NONE;
bool hasDigit=false, hasExp=false, hasSign=false, hasDot=false;
int i = i_begin;
for ( ;i<=i_end; ++i )
{
// blank
if ( s[i]==' ' )
{
return false;
}
// digit
else if ( s[i]>='' && s[i]<='' )
{
hasDigit = true; preType = DIGIT;
}
// sign
else if ( s[i]=='+' || s[i]=='-' )
{
if ( preType==EXP || preType==NONE )
{
hasSign=true; preType = SIGN;
}
else
{
return false;
}
}
// exp
else if ( s[i]=='e' || s[i]=='E' )
{
if ( (preType==DIGIT || preType==DOT) && !hasExp && hasDigit )
{
hasExp=true; preType=EXP;
}
else
{
return false;
}
}
// dot
else if ( s[i]=='.' )
{
if( !hasExp && !hasDot && (preType==DIGIT || preType==SIGN || preType==NONE ) )
{
hasDot=true; preType = DOT;
}
else
{
return false;
}
}
else
{
return false;
}
}
return preType==DIGIT || (preType==DOT && hasDigit);
}
};

【Valid Number】cpp的更多相关文章

  1. 【Valid Sudoku】cpp

    题目: Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules. The Sudoku board could ...

  2. 【Valid Palindrome】cpp

    题目: Given a string, determine if it is a palindrome, considering only alphanumeric characters and ig ...

  3. 【Valid Parentheses】cpp

    题目: Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the ...

  4. 【Palindrome Number】cpp

    题目: Determine whether an integer is a palindrome. Do this without extra space. click to show spoiler ...

  5. 【Single Number】cpp

    题目: Given an array of integers, every element appears twice except for one. Find that single one. No ...

  6. 【Longest Valid Parentheses】cpp

    题目: Given a string containing just the characters '(' and ')', find the length of the longest valid ...

  7. 【Letter Combinations of a Phone Number】cpp

    题目: Given a digit string, return all possible letter combinations that the number could represent. A ...

  8. 【Gray Code】cpp

    题目: The gray code is a binary numeral system where two successive values differ in only one bit. Giv ...

  9. 【Sort Colors】cpp

    题目: Given an array with n objects colored red, white or blue, sort them so that objects of the same ...

随机推荐

  1. CentOS学习笔记--系统服务 (daemons)

    系统服务 (daemons) 系统为了某些功能必须要提供一些服务 (不论是系统本身还是网络方面),这个服务就称为 service . 但是 service 的提供总是需要程序的运行吧!否则如何运行呢? ...

  2. MVC5 Identity 自定义用户和角色

    看代码基本就都能看懂了,增加了两个用户详细信息的表,角色表增加两个字段页面中实现树形显示. //IdentityModels.cs using System.Data.Entity; using Sy ...

  3. php字符串截取问题

    希望将一个字符串限长显示,如果该字符串超过一定长数,就截取前n个字符,后加省略号. 但是在英文和汉字混合的情况下会出现如下问题: 如果有这样一个字符串  $str="这是一个字符串" ...

  4. 深入PHP empty(),isset(),is_null()

    PHP empty(),isset(),is_null()的实例测试.   有关 PHP编程 的 empty(),isset() 还有 is_null() 这三个函数的用法讨论得已经很多了,而且很多资 ...

  5. php异常处理示例

    php异常处理使用示例,代码说明了普通错误和致命错误捕获及处理的方法.  代码如下: <?php //禁止错误输出 error_reporting(0); //设置错误处理器 set_error ...

  6. php教程一,变量

    php是一种动态脚本语言,比较适合web开发. php支持8种变量数据类型: 四种标量类型: boolean(布尔型) integer(整型) float(浮点型,也称作 double) string ...

  7. 17) JMS: java Message Service(Java消息服务)

         JMS是一个标准,就像EJB,有很多开源的,商业的实现,ms技术对应的规范是jsr914,规范的实现称为jms provider,常见的实现有ActiveMQ.JBoss MQ.IBM We ...

  8. express中使用 connect-flash 及其源码研究

    刚开始摸node.js, 在用express 4.x 的过程中 有一个connect-flash的玩意 如上图, 在 /reg 页面提交注册信息的时候 如若两次输入的密码不匹配则调用请求对象req的f ...

  9. UICollectionView [NSIndexPath section]: message sent to deallocated instance

    在UICollectionView上加UITapGestureRecognizer手势时,点击哪都报 [NSIndexPath section]: message sent to deallocate ...

  10. [php]如何更改wamp默认的mysq空密码?

    最近刚开始学php,爬坑中.上午看了会儿书,下了个源码,把文件部署到www下之后,也导入了sql文件,但是进入之后显示 = =  一开始不知道是什么.后来百度之后发现是mysql的问题,应该是源码中p ...