A valid number can be split up into these components (in order):
- A decimal number or an integer.
- (Optional) An
'e'
or'E'
, followed by an integer.
A decimal number can be split up into these components (in order):
- (Optional) A sign character (either
'+'
or'-'
). - One of the following formats:
- At least one digit, followed by a dot
'.'
. - At least one digit, followed by a dot
'.'
, followed by at least one digit. - A dot
'.'
, followed by at least one digit.
- At least one digit, followed by a dot
An integer can be split up into these components (in order):
- (Optional) A sign character (either
'+'
or'-'
). - At least one digit.
For example, all the following are valid numbers: ["2", "0089", "-0.1", "+3.14", "4.", "-.9", "2e10", "-90E3", "3e+7", "+6e-1", "53.5e93", "-123.456e789"]
, while the following are not valid numbers: ["abc", "1a", "1e", "e3", "99e2.5", "--6", "-+3", "95a54e53"]
.
Given a string s, return true if s is a valid number.
Input: s = "0"
Output: true
Input: s = "e"
Output: false
Input: s = "."
Output: false
Input: s = ".1"
Output: true
1 <= s.length <= 20
s consists of only English letters (both uppercase and lowercase), digits (0-9), plus '+', minus '-', or dot '.'.
Solutions (Click to expand)
-
Skip any white space
-
Check for a single sign
+
or-
-
If we are at the end of the string, return false
-
Check the next characters until we reach the end of the string, or reach the next non digit or
.
character. Keep track of the number of points and digits. -
If there are more than one points, or less than 1 digits, return false
-
If the next character is
e
orE
, repeat the same procedure for checking the next characters until the end of the string, or until the next non digit character. -
If we reach the end of the string, return true. If we are not at the end there are extra non digit or
.
character in the string, return false