-
Notifications
You must be signed in to change notification settings - Fork 0
/
reverseVowels.cpp
66 lines (63 loc) · 1.76 KB
/
reverseVowels.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
// https://leetcode.com/problems/reverse-vowels-of-a-string/
// 一头一尾两个指针向中间靠拢
// 这是最直观的算法
// 易错点:不要忽略了大写元音字母
class Solution {
public:
bool isvowel(const char c) {
std::set<char> vowel{'a', 'o', 'e', 'i', 'u',
'A', 'O', 'E', 'I', 'U'};
if (find(vowel.begin(), vowel.end(), c) != vowel.end())
return true;
else
return false;
}
string reverseVowels(string s) {
int i, j;
for (i=0, j=s.size()-1; i<j;) {
if (isvowel(s[i]) && isvowel(s[j])) {
std::swap(s[i++], s[j--]);
} else {
if(!isvowel(s[i]))
++i;
if(!isvowel(s[j]))
--j;
}
}
return s;
}
};
// accepted, but too slow, 992ms
class Solution {
public:
bool isvowel(const char c) {
std::array<char, 10> vowel{'a', 'o', 'e', 'i', 'u',
'A', 'O', 'E', 'I', 'U'};
int i;
for (i=0; i<10; ++i) {
if (vowel[i] == c)
break;
}
return i!=10;
}
string reverseVowels(string s) {
int i, j;
for (i=0, j=s.size()-1; i<j;) {
bool flag1 = isvowel(s[i]);
bool flag2 = isvowel(s[j]);
if (flag1 && flag2) {
std::swap(s[i++], s[j--]);
} else {
if(!flag1)
++i;
if(!flag2)
--j;
}
}
return s;
}
};
// 19ms
// 改进点:
// (1)如果简单的std::array 能满足需求,就不要上std::set 这些红黑树结构,拖慢了速度
// (2)缓存函数调用结果,不要重复调用函数。