/
012_NumericStrings.cpp
101 lines (80 loc) · 2.15 KB
/
012_NumericStrings.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
// Coding Interviews: Questions, Analysis & Solutions
// Harry He
#include <stdio.h>
void scanDigits(char** string);
bool isExponential(char** string);
bool isNumeric(char* string)
{
if(string == NULL)
return false;
if(*string == '+' || *string == '-')
++string;
if(*string == '\0')
return false;
bool numeric = true;
scanDigits(&string);
if(*string != '\0')
{
// for floats
if(*string == '.')
{
++string;
scanDigits(&string);
if(*string == 'e' || *string == 'E')
numeric = isExponential(&string);
}
// for integers
else if(*string == 'e' || *string == 'E')
numeric = isExponential(&string);
else
numeric = false;
}
return numeric && *string == '\0';
}
void scanDigits(char** string)
{
while(**string != '\0' && **string >= '0' && **string <= '9')
++(*string);
}
bool isExponential(char** string)
{
if(**string != 'e' && **string != 'E')
return false;
++(*string);
if(**string == '+' || **string == '-')
++(*string);
if(**string == '\0')
return false;
scanDigits(string);
return (**string == '\0') ? true : false;
}
// ==================== Test Code ====================
void Test(char* testName, char* string, bool expected)
{
if(testName != NULL)
printf("%s begins: ", testName);
if(isNumeric(string) == expected)
printf("Passed.\n");
else
printf("FAILED.\n");
}
int main(int argc, char* argv[])
{
Test("Test1", "100", true);
Test("Test2", "123.45e+6", true);
Test("Test3", "+500", true);
Test("Test4", "5e2", true);
Test("Test5", "3.1416", true);
Test("Test6", "600.", true);
Test("Test7", "-.123", true);
Test("Test8", "-1E-16", true);
Test("Test9", "1.79769313486232E+308", true);
printf("\n\n");
Test("Test10", "12e", false);
Test("Test11", "1a3.14", false);
Test("Test12", "1+23", false);
Test("Test13", "1.2.3", false);
Test("Test14", "+-5", false);
Test("Test15", "12e+5.4", false);
return 0;
}