LeetCode345. Reverse Vowels of a String

Write a function that takes a string as input and reverse only the vowels of a string.

Example 1:

Input: "hello"
Output: "holle"

Example 2:

Input: "leetcode"
Output: "leotcede"

Note:
The vowels does not include the letter "y".

这道题的关键在于如何同时交换两个元音字母。我们这里采取的方法是分别找到左边和右边的元音字母然后交换。

另外,我们这里使用了用数组来“哈希”字母的trick。

class Solution {
public:
	string reverseVowels(string s) {
		vector<int> v(256, 0);
		v['a'] = 1;
		v['e'] = 1;
		v['i'] = 1;
		v['o'] = 1;
		v['u'] = 1;

		v['A'] = 1;
		v['E'] = 1;
		v['I'] = 1;
		v['O'] = 1;
		v['U'] = 1;

		int left = 0, right = int(s.size() - 1);
		while (left < right) {
			while (left < right && !v[s[left]]) left++;
			while (left < right && !v[s[right]]) right--;
			swap(s[left], s[right]);
			left++; right--;
		}
		return s;
	}
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值