登录
首页 >  文章 >  前端

[算法]字符串中的反向单词

时间:2025-02-07 10:27:55 111浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《[算法]字符串中的反向单词》,以下内容主要包含等知识点,如果你正在学习或准备学习文章,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

反转字符串中单词的顺序

给定一个输入字符串 s,反转单词的顺序。一个单词定义为一系列非空格字符。s 中的单词至少由一个空格分隔。返回一个以相反顺序排列的单词字符串,单词之间由单个空格分隔。

关键要求:

  • 删除单词之间以及字符串开头/结尾处的多余空格。
  • 反转单词的顺序(而不是字符)。

示例 1:

输入:s = "the sky is blue"
输出:"blue is sky the"

示例 2:

输入:s = "  hello world  "
输出:"world hello"
解释:反转后的字符串不应包含前导或尾随空格。

示例 3:

输入:s = "a good   example"
输出:"example good a"
解释:需要将两个单词之间的多个空格减少为反转字符串中的单个空格。

解决方案:

以下 JavaScript 代码使用正则表达式高效地解决了这个问题:

var reverseWords = function(s) {
    // 使用正则表达式替换多个空格为单个空格,并去除首尾空格
    return s.replace(/\s+/g, ' ').trim().split(' ').reverse().join(' ');
};

代码解释:

  1. s.replace(/\s+/g, ' '): 使用正则表达式 /\s+/g 替换一个或多个空格 (\s+) 为单个空格。g 标志确保替换所有匹配项。

  2. .trim(): 去除字符串开头和结尾的多余空格。

  3. .split(' '): 根据空格将字符串分割成一个单词数组。

  4. .reverse(): 反转单词数组的顺序。

  5. .join(' '): 将反转后的单词数组连接成一个字符串,单词之间用单个空格分隔。

[算法]字符串中的反向单词

这个解决方案简洁明了,有效地处理了多余空格和单词反转的问题。 它避免了复杂的循环和条件语句,提高了代码的可读性和效率。

理论要掌握,实操不能落!以上关于《[算法]字符串中的反向单词》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>