牛骨文教育服务平台(让学习变的简单)
博文笔记

LeetCode Valid Number(判断字符串是否是合法的数字表示 )

创建时间:2016-07-25 投稿人: 浏览次数:586

思路:

1、如果是指数表现法,e后不能有小数

2、数字中有带有正负表示只能有一个

3、小数时点只能有一个

代码如下:

public class Solution
{
    public boolean isNumber(String s) {
        s = s.trim();
        int len = s.length();
        if (0 == len) return false;

        boolean hasE = false, hasDot = false, hasDigit = false, hasFirst = false;

        for (int i = 0; i < len; i++)
        {
            char c = s.charAt(i);
            if (c >= "0" && c <= "9") {
                hasFirst = hasDigit = true;
                continue;
            }

            switch (c) {
                case "e":
                    if (hasE || !hasDigit) return false;
                    hasE = true;

                    hasDot = true;
                    hasFirst = hasDigit = false;
                    break;
                case ".":
                    if (hasDot) return false;
                    hasDot = true;
                    hasFirst = true;
                    break;
                case "+":
                case "-":
                    if (hasFirst) return false;
                    hasFirst = true;
                    break;
                default:
                    return false;
            }
        }

        return  hasDigit;
    }
}


声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。