给你一个字符串 s ,仅反转字符串中的所有元音字母,并返回结果字符串。
元音字母包括 'a'、'e'、'i'、'o'、'u',且可能以大小写两种形式出现不止一次。
示例 1:
输入:s = "hello"
输出:"holle"
示例 2:
输入:s = "leetcode"
输出:"leotcede"
提示:
1 <= s.length <= 3 * 105
s 由 可打印的 ASCII 字符组成
解题思路:
双指针法
代码:
class Solution {
public:
string reverseVowels(string s) {
int n = s.length();
int i=0,j = n-1;
while(i<j){
while((i<n) && (s[i]!='a'&&s[i]!='e'&&s[i]!='o'&&s[i]!='u'&&s[i]!='i') && (s[i]!='A'&&s[i]!='E'&&s[i]!='O'&&s[i]!='U'&&s[i]!='I')){
i++;
}
while((j>0) &&(s[j]!='a'&&s[j]!='e'&&s[j]!='o'&&s[j]!='u'&&s[j]!='i') && (s[j]!='A'&&s[j]!='E'&&s[j]!='O'&&s[j]!='U'&&s[j]!='I'))
{
j--;
}
if(i<j){
swap(s[i],s[j]);
i++;
j--;
}
}
return s;
}
};