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.
[暴力解法]:
时间分析:
空间分析:
[优化后]:
时间分析:
空间分析:
[奇葩输出条件]:
[奇葩corner case]:
[思维问题]:
[英文数据结构或算法,为什么不用别的数据结构或算法]:
[一句话思路]:
[输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入):
[画图]:

[一刷]:
- +-号要求处于第一位,则index i = 0,不是它自己等于0
 - 单个字符'e'要用单引号扩起来
 
[二刷]:
- s = s.trim();必须要有等号,否则空格害事
 - 出错的情况直接return false, 不要设置变量,否则可能会拧回来
 
[三刷]:
[四刷]:
[五刷]:
[五分钟肉眼debug的结果]:
[总结]:
上面那张表
[复杂度]:Time complexity: O(n) Space complexity: O(1)
[算法思想:迭代/递归/分治/贪心]:
[关键模板化代码]:
[其他解法]:
[Follow Up]:
[LC给出的题目变变变]:
[代码风格] :
[是否头一次写此类driver funcion的代码] :
[潜台词] :
class Solution {
    public boolean isNumber(String s) {
        //trim first
        s = s.trim();
        //ini some flags
        boolean numberSeen = false;
        boolean pointSeen = false;
        boolean eSeen = false;
        //for loop: num, . , e, +-
        for (int i = 0; i < s.length(); i++) {
            if (s.charAt(i) >= '0' && s.charAt(i) <= '9') {
                numberSeen = true;
            }else if (s.charAt(i) == '.') {
                if (pointSeen == true || eSeen == true) {
                    return false;
                }
                pointSeen = true;
            }else if (s.charAt(i) == 'e') {
                if (pointSeen == true || eSeen == true || !(i >= 1 && s.charAt(i - 1) >= '0' && s.charAt(i - 1) <= '9')) {
                    return false;
                }
                eSeen = true;
                numberSeen = false;
            }else if (s.charAt(i) == '+' || s.charAt(i) == '-') {
                if (i != 0 && s.charAt(i - 1) != 'e') return false;
                numberSeen = false;
            }else {
                //directly return
                return false;
            }
        }
        return numberSeen;
    }
}
65. Valid Number 判断字符串是不是数字的更多相关文章
- valid number 判断字符串是否为有效数字
		
RT,面试题,给定一个字符串判断是否为科学计数法的有效数字.此题各种繁琐考虑.今天终于学会了用有限状态机来处理.理解之后简洁易懂.在此分享我的理解推导思路,大有收获啊. 网上有解法说先记录每个状态代表 ...
 - [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),有符号的兼容无符号的 合法的数字只有下列几种 ...
 - js 判断是不是数字||判断字符串是不是数字(正则表达式)
		
js使用正则表达式判断对象是不是数字,或者字符串是不是数字,或者是不是数字类型 //判断是不是一个数字 或者 一个字符串里全是数字 isNumber (value) { if (value === u ...
 - 【LeetCode】65. Valid Number
		
Difficulty: Hard More:[目录]LeetCode Java实现 Description Validate if a given string can be interpreted ...
 - 【一天一道LeetCode】#65. Valid Number
		
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Validat ...
 - 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" => ...
 - Valid Number,判断是否为合法数字
		
问题描述: Validate if a given string is numeric. Some examples:"0" => true" 0.1 " ...
 
随机推荐
- s2第六章继承和多态
			
public class Employee { //年龄 public int Age { get; set; } //性别 public Gender Gender { get; set; } // ...
 - PythonStudy1——Python 值拷贝 浅拷贝 深拷贝
			
拷贝:对值进行复制的过程 # 值拷贝:应用场景最多 ls = [1, 'abc', [10]] ls1 = ls # ls1直接将ls中存放的地址拿过来 # ls内部的值发生任何变化,ls1都会随 ...
 - golang-grpc-Unimplemented-desc
			
golang 调用grpc 服务方法时候提示:"rpc error: code = Unimplemented desc ="的错误, 这是由于pb中的package name 被 ...
 - Entity Framework教程翻译 ----  系列教程
			
Entity Framework教程(第二版) (翻译)Entity Framework技巧系列之十四 - Tip 56 (翻译)Entity Framework技巧系列之十三 - Tip 51 - ...
 - 第3章 Java数组(上): 一维数组和二维数组
			
3.数组及排序算法(2天) 3.1 数组的概述 2课时 3.2 一维数组的使用 3课时 3.3 多维数组的使用 3课时 3.4 数组中涉及到的常见算法 3课时 3.5 Arrays工具类的使用 3课时 ...
 - C/C++中的volatile简单描述
			
首先引入一篇博客: 1. 为什么用volatile? C/C++ 中的 volatile 关键字和 const 对应,用来修饰变量,通常用于建立语言级别的 memory barrier.这是 BS 在 ...
 - 01-简单编写http服务器
			
package com.day3; import java.io.IOException; import java.io.InputStream; import java.net.ServerSock ...
 - 刘志梅  201771010115 《面向对象程序设计(java)》 第九周学习总结
			
实验九 异常.断言与日志 实验时间 2018-10-25 1.实验目的与要求 (1) 程序中会出现的错误:用户输入错误.设备错误.代码错误.物理限制. 在Java程序设计语言中,异常对象都是派生于Th ...
 - day29单例模式的4种实现模式
			
单例模式的四种实现模式单例模式实现方式一: import settings class MySQL: __instance=None def __init__(self, ip, port): ...
 - py库:文本转为语音(pywin32、pyttsx)
			
http://blog.csdn.net/marksinoberg/article/details/52137547 Python 文本转语音 文本转为语音(使用Speech API) 需要安装 py ...