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

反转字符串中单词的顺序

给定一个输入字符串 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(' ');};

代码解释:

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

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

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

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

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

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

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

以上就是[算法]字符串中的反向单词的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1501242.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 23:23:41
下一篇 2025年12月19日 23:23:56

相关推荐

  • 在JavaScript中关闭

    JavaScript闭包是函数与其周围词法环境的组合。 换句话说,JavaScript闭包是一个函数,即使在创建它的作用域之外执行,也能记住其词法作用域(创建它的作用域)。这意味着函数可以“记住”其创建时的环境,包括当时作用域内的所有变量。 想象一下,您要快速邮寄一些文件。您将所有文件放入信封并密封…

    2025年12月19日
    000
  • 数字营销和网络设计公司班加罗尔 – 挖掘

    Digition,一家位于印度班加罗尔的领先数字营销和网站设计公司,致力于创新和成果导向。凭借其强大的能力,Digition帮助各种规模的企业建立强大的在线形象。公司提供全套解决方案,从设计视觉效果出色的网站到执行数据驱动的数字营销活动,一应俱全。 选择 Digition 的理由 选择 Digiti…

    2025年12月19日
    000
  • 理解JavaScript中的对象

    JavaScript对象是八种基本数据类型中的一种。不同于数字、字符串、布尔值等只存储单个值的原始数据类型,对象可以存储多个值,这些值以键值对的形式组织成属性。键通常是字符串或Symbol类型,值可以是任何数据类型。 对象初始化 const myObj = new Object();const my…

    2025年12月19日
    000
  • 了解VUE ND VUE 3之间的差异

    Vue.js 框架的演进带来了诸多改进,Vue 3 在性能、开发体验和灵活性方面都超越了其前身 Vue 2。让我们深入探讨两者间的关键差异: 1. API 的变革:选项 API vs. 组合式 API Vue 2 主要依赖于选项 API (Options API),通过 data、methods、c…

    2025年12月19日
    000
  • 最佳Python IDE:为您的开发旅程选择完美的工具

    选择合适的Python集成开发环境(IDE)能显著提升您的编程效率,无论您是新手还是资深开发者。合适的IDE不仅简化编码过程,还能提升生产力,让复杂任务更易于管理。 什么是IDE? 集成开发环境(IDE)是一种软件应用,提供全套工具简化编码,包括代码编辑器、调试器和自动化功能,将软件开发的各个核心组…

    2025年12月19日
    000
  • 创建网络视频应用程序

    本指南将指导您创建一个基于react框架的网络应用程序,用于流式播放您已创建的视频,延续了之前关于使用开放式web服务的博客文章。 我们将使用Vite构建工具来设置项目。 一、设置React TypeScript项目 首先,使用以下命令创建一个新的基于React模板的项目: npm create v…

    2025年12月19日
    000
  • JavaScript帽E雄辩

    JavaScript 练习题详解:三角形、FizzBuzz 和棋盘 本文将分享几道 javascript 练习题的解法,并详细解释思路。 1. 三角形循环 目标:使用循环在控制台打印如下三角形: ############################ 解法:观察到每行 ‘#&#8217…

    2025年12月19日
    000
  • 以不同的方式逆转数组

    JavaScript 提供多种方法逆转数组。本文将介绍几种常用的方法,并比较其优缺点。 1. 使用 reverse() 方法: reverse() 方法是最直接、最简洁的数组反转方法。它直接修改原始数组,不创建新的数组。 示例: const arr = [5, 2, 3, 7, 9, 15, 20]…

    2025年12月19日
    000
  • 如何将Ollama整合到Nextjs中

    利用ollama和next.js构建llm驱动应用 人工智能和大语言模型(LLM)正以前所未有的速度改变着我们的生活。新的模型和集成方案(例如AI代理和运营商)层出不穷,加入这个激动人心的浪潮势在必行。本文将指导您如何将Ollama与Next.js集成,构建基于LLM的应用程序。我们将学习如何下载开…

    2025年12月19日
    000
  • bun(仍然无法替换节点(但这是我一起使用它们的方式)

    bun的基准测试结果令人印象深刻,其http服务器性能在框架性能榜单中名列前茅,这让我眼前一亮。npm包的安装速度也显著提升,甚至让我考虑放弃pnpm。 然而,在实际使用过程中,我发现了一些问题。 最初,我对Bun宣传中的一些说法持怀疑态度,但现在我更倾向于认同其部分观点。 我遇到的主要问题在于对运…

    2025年12月19日
    000
  • 使用K快速启动指南的API性能测试

    高效REST API性能测试:K6实战指南 高质量的rest api应用不仅功能完善,更需具备卓越的性能。本文将深入探讨如何利用k6进行rest api性能测试,确保应用在各种负载下的稳定性、可扩展性和可靠性,从日常运行到突发高负载场景。 为什么要进行性能测试? 性能测试在REST API开发中至关…

    2025年12月19日
    000
  • 德里负担得起的SEO服务|当地的SEO专家古尔冈

    提升德里Prixelwork Interactive的SEO服务,助您网站排名更上一层楼,业绩增长更迅速!我们专业的本地SEO知识,确保您的网站获得更高的曝光度和投资回报率。 德里经济实惠的SEO服务 | 古尔冈本地SEO专家 SEO对您业务的重要性 | 您的企业在线推广是否举步维艰?如果您的网站在…

    2025年12月19日
    000
  • 优化JavaScript项目中的图像导入:一种模块化方法

    有效管理javascript或react项目中的图像,尤其是在处理大量资源时,至关重要。本文介绍一种模块化方法,通过集中导入导出图像来提高代码的可维护性、可扩展性和性能。 传统方法的弊端:直接导入 许多开发者最初会在每个组件中直接导入图像,例如: import logo from ‘./logo.p…

    2025年12月19日 好文分享
    000
  • 扁平的深嵌套物体

    本文介绍一种利用循环和数组方法扁平化深嵌套对象的JavaScript方法,该方法是针对每日JavaScript挑战#js-31的解决方案。 核心方法: 循环遍历对象: 使用for…in循环遍历普通JavaScript对象(POJO)的键值对。 for循环则用于遍历数组元素。递归: flatten…

    2025年12月19日
    000
  • Vue中的大问题开发人员需要知道

    Vue 3 虽然带来了诸多改进,但也为开发者带来了新的挑战。本文将探讨Vue 3开发中的一些主要痛点,帮助您在迁移或使用Vue 3开发新项目时做好准备。 1. Composition API 学习曲线 Composition API 是 Vue 3 的核心变化之一,它提升了代码组织性和可复用性。然而…

    2025年12月19日
    000
  • 计时器

    JavaScript计时器让您能够在指定时间执行代码,或以固定间隔重复执行。主要有两种计时器:setTimeout() 和 setInterval()。两者都用于安排代码在延迟后运行,但行为有所不同。 setTimeout() setTimeout() 在指定的延迟后仅执行一次函数或代码块。 工作原…

    2025年12月19日
    000
  • 了解黑匣子测试:通过Kepothing提高软件质量

    黑盒测试是软件测试中一项关键技术,它通过验证软件功能是否符合预期来确保应用程序质量。测试人员无需了解内部代码,而是专注于输入和输出结果的验证。 什么是黑盒测试? 黑盒测试是一种软件测试方法,测试人员完全不了解软件内部结构和代码。测试的重点是评估软件的功能是否满足需求规格说明书中定义的功能。 黑盒测试…

    2025年12月19日
    000
  • 边缘零信任(第1部分)

    利用JSON Web令牌 (JWT) 安全验证请求:详解及实践 本文将深入探讨json web令牌 (jwt) 的工作机制,以及如何在实际应用中利用其进行安全可靠的请求验证。jwt凭借其安全性与便捷性,已成为现代应用中身份验证和授权的热门选择。 一、JWT 结构与组成 JWT由三个部分组成: Hea…

    2025年12月19日
    000
  • 为什么您应该避免在REACT中避免使用危险的lysetinnerhtml?

    React 中的 属性允许开发者直接设置元素的 innerHTML 属性,无需任何消毒处理。 将不可信的用户输入直接插入此属性极其危险,可能导致严重的跨站脚本 (XSS) 安全漏洞。因此,应始终避免将不可信的用户输入传递给 dangerouslySetInnerHTML 属性。 最佳实践是完全避免使…

    2025年12月19日
    000
  • 货币化开源:可持续发展策略

    开源软件已彻底改变了科技领域,推动了创新、协作和透明度。然而,许多开发者和组织仍然面临着开源项目财务可持续性的巨大挑战。本文探讨了多种开源项目盈利策略,并参考了开放薪酬令牌许可证(OCTL)白皮书。 引言 开源项目的货币化是指在保持开放性和社区合作原则的同时,寻找创收途径。有效的货币化策略能够确保项…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信