-
Notifications
You must be signed in to change notification settings - Fork 523
/
Copy path15. Valid Number.cpp
82 lines (70 loc) · 1.94 KB
/
15. Valid Number.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*
Valid Number
============
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.
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.
Example 1:
Input: s = "0"
Output: true
Example 2:
Input: s = "e"
Output: false
Example 3:
Input: s = "."
Output: false
Example 4:
Input: s = ".1"
Output: true
Constraints:
1 <= s.length <= 20
s consists of only English letters (both uppercase and lowercase), digits (0-9), plus '+', minus '-', or dot '.'.
*/
class Solution
{
public:
bool isNumber(string s)
{
int pointSeen = 0, numSeen = 0, eSeen = 0, numAfterE = 0;
for (int i = 0; i < s.size(); ++i)
{
if (s[i] >= '0' && s[i] <= '9')
{
numSeen = 1;
numAfterE = 1;
}
else if (s[i] == '.')
{
if (eSeen || pointSeen)
return false;
pointSeen = 1;
}
else if (s[i] == 'e' || s[i] == 'E')
{
if (eSeen || !numSeen)
return false;
eSeen = 1;
numAfterE = 0;
}
else if (s[i] == '+' || s[i] == '-')
{
if (i != 0 && s[i - 1] != 'e')
return false;
}
else
return false;
}
return numSeen && numAfterE;
}
};