zoukankan      html  css  js  c++  java
  • 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.

    解决思路

    类似于这样的问题,说难也难,说容易也容易。

    难的地方在于很难一次写出freebug的代码,容易的地方在于枚举规则,仅此一条思路而已。

    大致需要注意的思路如下:

    1. s = s.trim();

    2. + / - 开头出现,e后面也可以出现;

    3. ‘.’的位置,注意题目中的".01"也是合法的;

    4. ‘001.1’这样的是否合法?

    程序

    public boolean isNumber(String s) {
    		if (s == null || s.trim().length() == 0) {
    			return false;
    		}
    
    		s = s.trim();
    
    		int idx = 0;
    		if (s.charAt(idx) == '+' || s.charAt(idx) == '-') {
    			++idx;
    		}
    
    		if (idx >= s.length()) {
    			return false;
    		}
    
    		boolean hasDot = false;
    		boolean hasE = false;
    		int dotIdx = idx;
    		int eIdx = idx;
    
    		for (int i = idx; i < s.length(); i++) {
    			char c = Character.toLowerCase(s.charAt(i));
    			if (c == '.') {
    				if (hasDot || hasE) {
    					return false;
    				}
    				hasDot = true;
    				dotIdx = i;
    				continue;
    			}
    			if (c == 'e') {
    				if (hasE) {
    					return false;
    				}
    				if (hasDot && i - 1 == idx
    						&& Character.toLowerCase(s.charAt(i - 1)) == '.') { // .e
    					return false;
    				}
    				hasE = true;
    				eIdx = i;
    				continue;
    			}
    			if (hasE && Character.toLowerCase(s.charAt(i - 1)) == 'e'
    					&& i != s.length() - 1
    					&& (s.charAt(i) == '-' || s.charAt(i) == '+')) { // 1e+
    				continue;
    			}
    			if (!Character.isDigit(c)) { // 'a''b'...
    				return false;
    			}
    		}
    
    		if (hasDot) {
    			if (s.substring(dotIdx + 1).length() == 0
    					&& s.substring(idx, dotIdx).length() == 0) { // '.'
    				return false;
    			}
    		}
    
    		if (hasE) {
    			if (s.substring(eIdx + 1).length() == 0) {
    				return false;
    			}
    			if (s.substring(idx, eIdx).length() == 0) {
    				return false;
    			}
    		}
    
    		return true;
    	}
    

    附上 Test Case

    String[] s = { "0", " 0.1", "abc", "1 a", "2e10", "0.1e-10", ".01",
    				"e10", "-1e-10", "1e", ".", "3.", ".e1", "4e+", "46.e3" };
    

    Output

    0 true
     0.1 true
    abc false
    1 a false
    2e10 true
    0.1e-10 true
    .01 true
    e10 false
    -1e-10 true
    1e false
    . false
    3. true
    .e1 false
    4e+ false
    46.e3 true

  • 相关阅读:
    StringHelper类的代码也写得不错,值得好好学习学习
    开发感慨
    取地址参数的方法
    在C#中运用SharpZipLib和unrar进行解压缩
    我的模板分析引擎类PHP的.net开发方法功能介绍篇
    分析模板的一段简单快速的算法片段
    关于文件操作的一些感悟
    关于自定义模板的设计
    JS中的函数、Bom、DOM及JS事件 pixel
    什么是CSS盒模型及利用CSS对HTML元素进行定位的实现(含h5/css3新增属性) pixel
  • 原文地址:https://www.cnblogs.com/harrygogo/p/4738944.html
Copyright © 2011-2022 走看看