LeetCode题练习与总结:反转字符串中的单词--151

一、题目描述

给你一个字符串 s ,请你反转字符串中 单词 的顺序。

单词 是由非空格字符组成的字符串。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"
解释:如果两个单词间有多余的空格,反转后的字符串需要将单词间的空格减少到仅有一个。

提示:

  • 1 <= s.length <= 10^4
  • s 包含英文大小写字母、数字和空格 ' '
  • s 中 至少存在一个 单词

二、解题思路

  1. 首先,我们需要去除字符串s的前导空格和尾随空格,同时将字符串中间多余的空格缩减为一个空格。
  2. 然后,我们将整个字符串反转。
  3. 接下来,我们需要遍历反转后的字符串,将每个单词反转回原来的顺序。

三、具体代码

class Solution {public String reverseWords(String s) {// 去除前导和尾随空格,并将中间多余空格缩减为一个空格StringBuilder sb = trimSpaces(s);// 反转整个字符串reverse(sb, 0, sb.length() - 1);// 反转每个单词reverseEachWord(sb);return sb.toString();}private StringBuilder trimSpaces(String s) {int left = 0, right = s.length() - 1;// 去除前导空格while (left <= right && s.charAt(left) == ' ') left++;// 去除尾随空格while (left <= right && s.charAt(right) == ' ') right--;// 将中间多余空格缩减为一个空格StringBuilder sb = new StringBuilder();while (left <= right) {char c = s.charAt(left);if (c != ' ') {sb.append(c);} else if (sb.charAt(sb.length() - 1) != ' ') {sb.append(c);}left++;}return sb;}private void reverse(StringBuilder sb, int start, int end) {while (start < end) {char temp = sb.charAt(start);sb.setCharAt(start, sb.charAt(end));sb.setCharAt(end, temp);start++;end--;}}private void reverseEachWord(StringBuilder sb) {int n = sb.length();int start = 0, end = 0;while (start < n) {// 循环至单词的末尾while (end < n && sb.charAt(end) != ' ') end++;// 翻转单词reverse(sb, start, end - 1);// 更新start,去找下一个单词end++;start = end;}}
}

四、时间复杂度和空间复杂度

1. 时间复杂度
  • trimSpaces 方法:这个方法遍历了整个字符串一次,所以时间复杂度是 O(n),其中 n 是字符串的长度。
  • reverse 方法:这个方法是用来翻转字符串的一部分,它的时间复杂度是 O(m),其中 m 是要翻转的部分的长度。
  • reverseEachWord 方法:这个方法遍历了整个字符串一次,并且在每个单词上调用了一次 reverse 方法。假设单词的平均长度是 k,那么这个方法的时间复杂度是 O(n + k),其中 n 是字符串的长度,k 是单词的平均长度。

综合起来,整个算法的时间复杂度是 O(n + k),因为 trimSpaces 和 reverseEachWord 都是遍历整个字符串,而 reverse 是在单个单词上操作,所以单词的总长度是 n。

2. 空间复杂度
  • trimSpaces 方法:这个方法创建了一个新的 StringBuilder 来存储处理后的字符串,所以空间复杂度是 O(n),其中 n 是字符串的长度。
  • reverse 方法和 reverseEachWord 方法:这两个方法都是原地操作,没有使用额外的空间,所以它们的空间复杂度是 O(1)。

综合起来,整个算法的空间复杂度是 O(n),因为 trimSpaces 方法创建了一个新的 StringBuilder 来存储处理后的字符串。

五、总结知识点

  1. 字符串处理:对字符串进行遍历、去除前后空格、缩减中间多余空格等操作。

  2. StringBuilder 类的使用:StringBuilder 是一个可变的字符序列,用于高效地拼接字符串、修改字符串内容等。

  3. 字符串反转:通过交换字符串首尾字符的位置,实现字符串的反转。

  4. 循环和条件语句:使用 while 循环和 if 条件语句来控制程序的逻辑流程。

  5. 字符数组与字符串的转换:StringBuilder 在内部维护一个字符数组,可以通过 append 方法添加字符,最终通过 toString 方法转换为字符串。

  6. 边界条件处理:在去除前后空格和反转字符串时,需要考虑字符串为空或只有一个字符的边界情况。

  7. 函数封装:将去除空格、反转字符串、反转每个单词等功能封装成单独的函数,提高代码的可读性和可维护性。

  8. 指针或索引的使用:在遍历字符串时,使用指针或索引来跟踪当前处理的位置。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/42398.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

速盾:好的cdn服务器

CDN&#xff08;Content Delivery Network&#xff09;是指内容分发网络&#xff0c;是一种将网站的静态内容&#xff08;如图片、音频、视频&#xff09;缓存在分布式的服务器节点上&#xff0c;通过就近访问用户的请求&#xff0c;提供快速可靠的内容传输服务的技术。 好的C…

HTML5文本标签、图像标签、超链接

一、文本样式标签 字体样式标签&#xff1a; 加粗&#xff1a;<strong>…</strong> 斜体&#xff1a; < em >…</ em> eg&#xff1a; <h3>徐志摩人物简介</h3> <p> <strong>1910</strong>年入杭州学堂<br/> &l…

微信小程序 - 本地存储 增加有效期

小程序的本地存储API提供了wx.setStorageSync和wx.setStorage来存储数据&#xff0c;注意的是&#xff0c;小程序的本地存储并没有明确的有效期设置&#xff0c;存储的数据在不超过限制的情况下&#xff0c;会一直保留。 一、小程序本地存储API 小程序的本地存储API提供了设置…

WEB06JavaScriptAjax

基础语法 引入方式 引入方式 内部脚本&#xff1a;将JS代码定义在HTML页面中 JavaScript代码必须位于<script></script>标签之间 在HTML文档中&#xff0c;可以在任意地方&#xff0c;放置任意数量的<script> 一般会把脚本置于<body>元素的底部&a…

常见的气体流量计有哪些?

1.气体涡轮流量计 适用场合&#xff1a;流量变化小&#xff0c;脉动流频率小&#xff0c;中低压洁净天然气优点 1.精度高&#xff0c;重复性好 2.测量范围广&#xff0c;压损小&#xff0c;安装维修方便 3.具有较高的抗电磁干扰和抗震动能力缺点&#xff1a;分辨率低&#xff…

活动:不要卷模型,要卷应用

如何理解李彦宏说的“不要卷模型&#xff0c;要卷应用” 1. 现状 现如今&#xff0c;是否具备独立的 AI 技术似乎已经成为衡量一个互联网企业是否成功的标志。各家都在竭尽全力卷模型、卷数据、卷训练效果&#xff0c;市面上仅是语言类 AI 就多达十几种&#xff0c;但从一名消…

浏览器中js外挂脚本的执行方式

1、开发工具控制台交互执行 网页中按F12打开开发者工具&#xff0c;选择“控制台”&#xff0c;键入js脚本命令回车执行&#xff0c;适用于临时使用脚本逻辑简单的场景&#xff0c;实例如下&#xff1a; // 获取网页元素的文本脚本 var elem document.getElementById("…

2-添加库

本节将学习如何在项目中创建和使用库&#xff0c;还将看到如何使库的使用成为可选的。 本节中使用的示例代码下载见step1-简单开始cmake实践-CSDN博客。 练习1 -创建一个库 要在CMake中添加一个库&#xff0c;使用add_library()命令并指定哪些源文件应该组成该库。 我们可…

接入应用内支付服务,提高商业变现效率

在当今竞争激烈的移动应用市场中&#xff0c;开发者们面临着提升应用商业变现能力的挑战。用户体验的流畅性和支付的安全性至关重要。 HarmonyOS SDK应用内支付服务&#xff08;IAP Kit&#xff09;为开发者提供了一站式的解决方案&#xff0c;简化了应用内支付的接入流程&…

C嘎嘎:类和对象(一)

目录 面向过程和面向对象的初步认识 类的引入 类的定义 类的访问限定符及封装 访问限定符 封装 类的作用域 类的实例化 类对象模型 如何计算类对象大小 结构体内存对齐规则 this指针 this指针的引出 this指针的特性 类的6个默认成员函数 构造函数 概念 特性 …

喜讯丨美格智能通过国际EcoVadis平台认证企业社会责任并荣获承诺奖章,彰显可持续发展实力

作为全球领先的无线通信模组及解决方案提供商&#xff0c;美格智能在社会责任领域再创新高。近日&#xff0c;美格智能凭借在企业社会责任和可持续性采购发展方面的卓越表现&#xff0c;通过国际在线权威评价机构EcoVadis对公司环境、劳工与人权、商业道德、可持续采购等方面审…

根据空格、制表符、回车符等分割字符串re.split

【小白从小学Python、C、Java】 【考研初试复试毕业设计】 【Python基础AI数据分析】 根据空格、制表符、 回车符等分割字符串 re.split [太阳]选择题 根据给定的Python代码&#xff0c;哪个选项是正确的&#xff1f; import re pattern r\s print(f"【显示】pattern{…

高清图片压缩无水印小程序源码系统 前后端分离 带完整的安装代码包以及搭建教程

系统概述 在当今的数字化时代&#xff0c;图片作为信息传播的重要载体&#xff0c;其质量和传输效率直接影响到用户体验。然而&#xff0c;高清图片往往伴随着较大的文件体积&#xff0c;这不仅会占用大量存储空间&#xff0c;还会拖慢网页或应用的加载速度。因此&#xff0c;…

热烈祝贺!全视通多家客户上榜全球自然指数TOP100!

2024年6月18日&#xff0c;全球医疗机构自然指数TOP100榜单发布&#xff0c;中国医疗机构在其中的表现尤为引人注目。 根据《自然》杂志网站发布的数据&#xff0c;此次公布的排名是基于&#xff08;2023年3月1日至2024年2月29日&#xff09;的统计数据&#xff0c;全球医疗机构…

Python在网络爬虫和数据抓取中的应用

Python在网络爬虫和数据抓取中的应用 引言 在数字化时代&#xff0c;数据的价值日益凸显。无论是市场趋势分析&#xff0c;还是个人偏好预测&#xff0c;数据都扮演着至关重要的角色。Python&#xff0c;作为一种功能强大、语法简洁的编程语言&#xff0c;为数据的获取、处理…

旗晟机器人AI智能算法有哪些?

在当今迅猛发展的工业4.0时代&#xff0c;智能制造和自动化运维已然成为工业发展至关重要的核心驱动力。伴随技术的持续进步&#xff0c;工业场景中的运维巡检已不再单纯地依赖于传统的人工运维方式&#xff0c;而是愈发多地融入了智能化的元素&#xff0c;其中智能巡检运维系统…

前端Din字体和造字工房力黑字体文件

Din 字体是一种经典的、简洁的无衬线字体&#xff0c;它源自1930年代的德国交通标志设计。 造字工房力黑字体适用于数字&#xff0c;驾驶舱标题等统计界面 DIN-Medium.otf 案例 造字工房力黑.TTF 案例

记录一次MySql锁等待 (Lock wait timeout exceeded)异常

[TOC](记录一次MySql锁等待 (Lock wait timeout exceeded)异常) Java执行一个SQL查询未提交&#xff0c;遇到1205错误。 java.lang.Exception: ### Error updating database. Cause: java.sql.SQLException: Lock wait timeout exceeded; try restarting transactionCluster…

动手学深度学习6.2 图像卷积-笔记练习(PyTorch)

以下内容为结合李沐老师的课程和教材补充的学习笔记&#xff0c;以及对课后练习的一些思考&#xff0c;自留回顾&#xff0c;也供同学之人交流参考。 本节课程地址&#xff1a;卷积层_哔哩哔哩_bilibili 代码_哔哩哔哩_bilibili 本节教材地址&#xff1a;6.2. 图像卷积 — 动…

Python使用watchdog库实现监控文件系统的更改

1. 先下载对应库&#xff1a; pip install watchdog import time from watchdog.observers import Observer from watchdog.events import FileSystemEventHandlerclass FileChangeHandler(FileSystemEventHandler):def on_modified(self, event):# 当文件被修改时触发此方法…