Problem
Given a 0-indexed string s, permute s to get a new string t such that:
All consonants remain in their original places. More formally, if there is an index
iwith0 <= i < s.lengthsuch thats[i]is a consonant, thent[i] = s[i].The vowels must be sorted in the nondecreasing order of their ASCII values. More formally, for pairs of indices
i,jwith0 <= i < j < s.lengthsuch thats[i]ands[j]are vowels, thent[i]must not have a higher ASCII value thant[j].
Return the resulting string.
The vowels are 'a', 'e', 'i', 'o', and 'u', and they can appear in lowercase or uppercase. Consonants comprise all letters that are not vowels.
Example 1:
Input: s = "lEetcOde"
Output: "lEOtcede"
Explanation: 'E', 'O', and 'e' are the vowels in s; 'l', 't', 'c', and 'd' are all consonants. The vowels are sorted according to their ASCII values, and the consonants remain in the same places.
Example 2:
Input: s = "lYmpH"
Output: "lYmpH"
Explanation: There are no vowels in s (all characters in s are consonants), so we return "lYmpH".
Constraints:
1 <= s.length <= 105sconsists only of letters of the English alphabet in uppercase and lowercase.
Solution
/**
* @param {string} s
* @return {string}
*/
var sortVowels = function(s) {
var vowels = s.split('')
.filter(isVowels)
.sort((a, b) => a.charCodeAt(0) - b.charCodeAt(0));
var res = '';
var index = 0;
for (var i = 0; i < s.length; i++) {
if (isVowels(s[i])) {
res += vowels[index++];
} else {
res += s[i];
}
}
return res;
};
var isVowels = function(char) {
var chars = ['a', 'e', 'i', 'o', 'u'];
return chars.includes(char.toLowerCase()) || chars.includes(char.toUpperCase());
};
Explain:
nope.
Complexity:
- Time complexity : O(n * log(n)).
- Space complexity : O(n).