题目描述
请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100",“5e2”,"-123",“3.1416"和”-1E-16"都表示数值。 但是"12e",“1a3.14”,“1.2.3”,"±5"和"12e+4.3"都不是。
class Solution {
public:
bool isNumeric(string s)
{
int i=0,j=s.size();
while(i<=j&&s[i]==' ') i++;
while(i<=j&&s[j]==' ') j++;
if(i>j) return false; //删除字符串为空
s=s.substr(i,j-i+1);
if(s[0]=='+'||s[0]=='-') s=s.substr(1);
if(s.empty()||(s[0]=='.'&&s.size()==1)) return false;//删除+,-,.
int dot=0,e=0;
for(int i=0;i<s.size();i++)
{
if(s[i]>='0'&&s[i]<='9');
else if(s[i]=='.')
{
dot++;
if(dot>1||e) return false; //删除有两个.的,以及类似于12e.12的数字
}
else if(s[i]=='e'||s[i]=='E')
{
e++;
if(i + 1 == s.size() || !i ||e > 1||i==1&&s[0]=='.') return false;//删除123e,.e, e的个数大于1,e1,
if(s[i+1]=='+'||s[i+1]=='-')
{
if(i+2==s.size()) return false;//删除12e+
i++;
}
}
else return false;
}
return true;
}
};