
给定一个字符串 s,仅反转字符串中的所有元音并返回它。
元音是 'a'、'e'、'i'、'o' 和 'u',它们可以以小写和大写形式出现多次。
为了解决这个问题,我们需要识别字符串中的所有元音,颠倒它们的顺序,然后将它们放回原来的位置。这可以使用两种方法来完成:
function reversevowelsbruteforce(s: string): string {
const vowels = new set(['a', 'e', 'i', 'o', 'u', 'a', 'e', 'i', 'o', 'u']);
let vowellist: string[] = [];
// extract vowels from the string
for (let char of s) {
if (vowels.has(char)) {
vowellist.push(char);
}
}
// reverse the list of vowels
vowellist.reverse();
// create a result array to build the output string
let result: string[] = [];
let vowelindex = 0;
// reconstruct the string with reversed vowels
for (let char of s) {
if (vowels.has(char)) {
result.push(vowellist[vowelindex]);
vowelindex++;
} else {
result.push(char);
}
}
return result.join('');
}
暴力解决方案效果很好,但使用额外的空间来存储元音和结果数组。
function reversevowelsoptimized(s: string): string {
const vowels = new set(['a', 'e', 'i', 'o', 'u', 'a', 'e', 'i', 'o', 'u']);
let sarray = s.split('');
let left = 0;
let right = sarray.length - 1;
while (left < right) {
while (left < right && !vowels.has(sarray[left])) {
left++;
}
while (left < right && !vowels.has(sarray[right])) {
right--;
}
if (left < right) {
[sarray[left], sarray[right]] = [sarray[right], sarray[left]];
left++;
right--;
}
}
return sarray.join('');
}
console.log(reverseVowelsBruteForce("hello")); // "holle"
console.log(reverseVowelsBruteForce("leetcode")); // "leotcede"
console.log(reverseVowelsBruteForce("aA")); // "Aa"
console.log(reverseVowelsBruteForce("")); // ""
console.log(reverseVowelsBruteForce("bcdfg")); // "bcdfg"
console.log(reverseVowelsOptimized("hello")); // "holle"
console.log(reverseVowelsOptimized("leetcode")); // "leotcede"
console.log(reverseVowelsOptimized("aA")); // "Aa"
console.log(reverseVowelsOptimized("")); // ""
console.log(reverseVowelsOptimized("bcdfg")); // "bcdfg"
字符串操作:
双指针技术:
基于角色的操作:
通过练习此类问题和策略,您可以提高解决问题的能力,并为各种编码挑战做好更好的准备。
以上就是Typescript 编码编年史:字符串的反转元音的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号