LetCode Valid Number(문자열이 올바른 숫자 표현인지 판단)

1355 단어 #
아이디어:
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;
    }
}

좋은 웹페이지 즐겨찾기