-
Notifications
You must be signed in to change notification settings - Fork 0
/
065.go
70 lines (65 loc) · 1.12 KB
/
065.go
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
package p065
/**
Validate if a given string is numeric.
Some examples:
"0" => true
" 0.1 " => true
"abc" => false
"1 a" => false
"2e10" => true
Note: It is intended for the problem statement to be ambiguous.
You should gather all requirements up front before implementing one.
*/
func isNumber(s string) bool {
bs := []byte(s)
l, h := 0, len(bs)-1
for l <= h && bs[l] == ' ' {
l++
}
for h >= l && bs[h] == ' ' {
h--
}
if l > h {
return false
}
if bs[l] == '-' || bs[l] == '+' {
l++
}
for l <= h && bs[l] >= '0' && bs[l] <= '9' {
l++
}
if l > h {
return true
}
lnum := l > 0 && (bs[l-1] >= '0' && bs[l-1] <= '9')
rnum := false
dot := bs[l] == '.'
if dot {
l++
for l <= h && bs[l] >= '0' && bs[l] <= '9' {
l++
}
rnum = bs[l-1] >= '0' && bs[l-1] <= '9'
}
if l > h {
return dot && (lnum || rnum)
} else if !lnum && !rnum {
return false
}
exp := bs[l] == 'e'
l++
if !exp {
return false
}
if l <= h && (bs[l] == '-' || bs[l] == '+') {
l++
}
for l <= h && bs[l] >= '0' && bs[l] <= '9' {
l++
}
if l <= h {
return false
}
rnum = bs[l-1] >= '0' && bs[l-1] <= '9'
return rnum
}