g0001_0100.s0065_valid_number.Solution Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-java Show documentation
Show all versions of leetcode-in-java Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
package g0001_0100.s0065_valid_number;
// #Hard #String #2022_02_19_Time_4_ms_(46.38%)_Space_42_MB_(38.62%)
public class Solution {
public boolean isNumber(String s) {
if (s == null || s.length() == 0) {
return false;
}
boolean eSeen = false;
boolean numberSeen = false;
boolean decimalSeen = false;
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (c >= 48 && c <= 57) {
numberSeen = true;
} else if (c == '+' || c == '-') {
if (i == s.length() - 1
|| (i != 0 && s.charAt(i - 1) != 'e' && s.charAt(i - 1) != 'E')) {
return false;
}
} else if (c == '.') {
if (eSeen || decimalSeen) {
return false;
}
decimalSeen = true;
} else if (c == 'e' || c == 'E') {
if (i == s.length() - 1 || eSeen || !numberSeen) {
return false;
}
eSeen = true;
} else {
return false;
}
}
return numberSeen;
}
}