题目描述
请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值。 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是
运行时间:16ms
占用内存:9288k
思路其实也还行,能理解,可能想不全一下子;想全了也还有个问题,就是if else把握好啊朋友。
public class Solution {
public boolean isNumeric(char[] str) {
if(str == null || str.length == 0 )
return false;
boolean hasE = false;
//boolean hasSig = false;
boolean hasDem = false;
for(int i=0; i<str.length; i++){
if(str[i] == 'e' || str[i] == 'E'){
//E的后面一定要有数字(可能中间插个±)
if(i == str.length-1)
return false;
//只能有一个E
if(hasE)
return false;
hasE = true;
}
else if(str[i] == '+' || str[i] == '-'){
//出现在第一个位置上
//if(i == 0)
//hasSig = true;
//不是出现在第一个位置上,并且其前面也没有e/E
if(i!=0 && (str[i - 1] != 'e' && str[i - 1] != 'E') )
return false;
}
else if (str[i] == '.'){
//小数点只能出现一次 且必须出现在e前面
//不是第一次出现了
if(hasDem)
return false;
else
hasDem = true;
//出现在E后面
if(hasE)
return false;
}
else if(str[i] < '0' || str[i] > '9')
return false;
}
return true;
}
}