zoukankan      html  css  js  c++  java
  • Leetcode:65. Valid Number

    Description

    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.

    思路

    • 这个题简直就是恶心。按照剑指offer上的思路来做,简直不要太坑。

    代码

    class Solution {
    public:
        bool isNumber(string s) {
            int len = s.size();
            if(len == 0) return false;
            
            int i = 0;
            while(i < len && s[i] == ' ') i++;
            if(i < len && (s[i] == '+' || s[i] == '-'))
                i++;
            if(i == len) return false;
            
            bool digit = false, digit2 = false;
            if(s[i] >= '0' && s[i] <= '9'){
                digit = true;
                while(i < len && s[i] >= '0' && s[i] <= '9') i++;
            }
            
            bool isExpon = false, judge = false, isD = false;
            if(i < len && s[i] == '.'){
                isD = true;
                i++;
                while(i < len && s[i] >= '0' && s[i] <= '9'){
                    digit2 = true;
                    i++;
                }
                
                
                if(i < len && (s[i] == 'e' || s[i] == 'E')){
                    judge = true;
                    isExpon = isValidOfE(s, i, len);
                }
                
                while(i < len && s[i] == ' ')
                    i++;
            }
            else if(i < len && (s[i] == 'e' || s[i] == 'E')){
                judge = true;
                isExpon = isValidOfE(s, i, len);
            }
            
            while(i < len && s[i] == ' ')
                i++;
                
            if(i != len)
                return false;
                
             if(isD && !digit && !digit2)
                return false;
         
            if(judge){
                if(!isExpon) return false;
                
                return (digit || (isD && digit2));
            }
            return true;
        }
        
        bool isValidOfE(string& str, int &i, int len){
            if(str[i] == 'e' || str[i] == 'E')
                i++;
            
            if(i < len && (str[i] == '-' || str[i] == '+'))
                i++;
            
            if(i == len) return false;
            
            if(str[i] >= '0' && str[i] <= '9'){
                while(i < len && (str[i] >= '0' && str[i] <= '9'))
                    i++;
                    
                return true;
            }
            else return false;
        }
    };
    
  • 相关阅读:
    Linux课程实践一:Linux基础实践(SSH)
    《恶意代码分析实战》读书笔记 静态分析高级技术一
    Linux课程实践四:ELF文件格式分析
    Linux课程实践三:简单程序破解
    Linux课程实践二:编译模块实现内核数据操控
    2020.12.19 加分项和课程意见/建议
    博客已换
    [题解] LuoguP4983 忘情
    [题解] LuoguP4767 [IOI2000]邮局
    [题解] LuoguP2791 幼儿园篮球题
  • 原文地址:https://www.cnblogs.com/lengender-12/p/6919864.html
Copyright © 2011-2022 走看看