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.

    class Solution {
    private:
        //1234
        bool isonlydigits(const string& s,int l,int r)
        {
            if(l>r) return false;
            
            for(int i=l;i<=r;i++)
                if(s[i]<'0' || s[i]>'9'return false;  
            return true;
        }
        //+ -
        bool isnum(const string& s,int l,int r)
        {
            if(l>r)return false;
            if(s[l]=='+' || s[l]=='-'return isnum(s,l+1,r);
            return isonlydigits(s,l,r);
        }
        //0.22
        bool isposfloat(const string& s,int l,int r)
        {
            if(l>r)return false;

            if(s[l]=='.'return isonlydigits(s,l+1,r);
            if(s[r]=='.'return isonlydigits(s,l,r-1);
            for(int i=l+1;i<=r-1;i++)
            if(s[i]=='.')
                return isonlydigits(s,l,i-1) && isonlydigits(s,i+1,r);
            return isonlydigits(s,l,r);
        }
        //+- 0.22
        bool isfloat(const string& s,int l,int r)
        {
            if(l>r)return false;

            if(s[l]=='+' || s[l]=='-'return isposfloat(s,l+1,r);
            return isposfloat(s,l,r);
        }
    public:
        bool isNumber(const char *s) 
        {
            //trim
            string str="";
            int len=strlen(s);
            int l=0;
            while(l<len && s[l]==' ') l++;
            int r=len-1;
            while(r>=0 && s[r]==' ') r--;
            for(int i=l;i<=r;i++)
                str=str+s[i];
            //only 1-9 . e + -
            for(int i=0;i<str.length();i++)
            {
                if(str[i]>='0' || str[i]<='9' || str[i]=='.' 
                || str[i]=='+' || str[i]=='-' || str[i]=='e' || str[i]=='E')
                {
                    
                }
                else return false;
            }
            //split by e
            for(int i=0;i<str.length();i++)
            if(str[i]=='e' || str[i]=='E')
            {
                return isfloat(str,0,i-1) && isnum(str,i+1,str.length()-1);
            }
            //no e
            return isfloat(str,0,str.length()-1);
        }
    }; 
  • 相关阅读:
    BZOJ2527[Poi2011]Meteors——整体二分+树状数组
    [UOJ422][集训队作业2018]小Z的礼物——轮廓线DP+min-max容斥
    BZOJ4817[Sdoi2017]树点涂色——LCT+线段树
    BZOJ4269再见Xor——高斯消元解线性基
    BZOJ4241历史研究——回滚莫队
    [十二省联考2019]字符串问题——后缀自动机+parent树优化建图+拓扑序DP+倍增
    [十二省联考2019]异或粽子——可持久化trie树+堆
    [CF594E]Cutting the Line
    [CF1246F]Cursor Distance
    [CF1246E]To Make 1
  • 原文地址:https://www.cnblogs.com/erictanghu/p/3759467.html
Copyright © 2011-2022 走看看