第十七天 翻转字符串里的单词

建议:这道题目基本把 刚刚做过的字符串操作 都覆盖了,不过就算知道解题思路,本题代码并不容易写,要多练一练。 题目链接:https://leetcode.cn/problems/reverse-words-in-a-string/ 视频讲解:https://www.bilibili.com/video/BV1uT41177fX

一、看到题目的第一想法

  1. 题目要求理解 :给定一个字符串 s,反转字符串中单词的顺序,同时要去除首尾和中间多余的空格,保证单词之间只有一个空格分隔。比如 " hello world! " 要变成 "world! hello"
  2. 核心思路:从字符串的末尾向前遍历,先跳过空格,找到单词的末尾位置;再继续向前遍历,找到单词的开头位置;把这个单词截取出来存入容器;再跳过中间的空格,重复这个过程,直到遍历完整个字符串。最后把容器里的单词按顺序拼接起来,中间用一个空格隔开。
  3. 初步实现念头
    • 用双指针 ijj 标记单词的末尾,i 标记单词的开头,从后往前遍历。
    • 遇到非空格字符就移动 i 继续向前,遇到空格就把 [i+1, j] 这个区间的单词截取出来,存入 vector<string>
    • 最后遍历容器,把单词拼接成结果字符串,中间加上空格。

二、实现过程中遇到的困难

  1. 边界条件的处理
    • 一开始没有考虑字符串开头 / 结尾的连续空格,比如 " a b c ",导致截取单词时出现空字符串,拼接后出现多余空格。后来才想到用 while 循环先跳过所有空格,再标记单词的起始和结束位置。
    • 循环条件容易越界:比如 while (i >= 0 && s[i] != ' '),一开始忘记加 i >= 0,当遍历到字符串开头时,i 变成负数,访问 s[i] 会报错。
  2. 截取子串 substr 的参数理解错误
    • 一开始搞混了 substr(pos, len) 的参数含义,错误地写成 s.substr(i, j - i + 1),导致截取的单词长度不对。后来才纠正过来:substr 第一个参数是起始下标,第二个参数是长度,所以从 i+1 开始,长度是 j - i 才正确。
  3. 拼接时多余空格的问题
    • 一开始直接在每个单词后面都加一个空格,导致结果字符串末尾多出一个空格。后来才改成 "不是最后一个单词才加空格",用 if (n != wordsVector.size() - 1) 来控制。
  4. 单词连续空格的处理
    • 一开始没有处理单词之间的多个空格,导致截取时把多个空格也当成了分隔符,产生空字符串。后来才在截取完一个单词后,用 while (i >= 0 && s[i] == ' ') 把中间的所有空格都跳过,保证每次只处理一个单词。

三、今日收获心得

  1. 从后往前遍历的技巧这道题让我学会了 "反向遍历" 的思路:从字符串末尾开始找单词,天然就实现了单词顺序的反转,不需要再额外反转整个单词列表,简化了逻辑。这种思路在处理反转类、分隔类字符串问题时非常实用。
  2. substr 与区间操作的巩固 彻底搞懂了 substr(pos, len) 的用法,以及如何用两个指针来确定子串的区间。同时也加深了对 "左闭右开" 区间的理解,避免了截取子串时的长度错误。
  3. 边界与特殊情况的鲁棒性处理 这道题包含了很多特殊情况:空字符串、全是空格的字符串、首尾有空格、单词间多个空格、单个单词的字符串等。通过这次实现,我学会了用 while 循环来过滤掉所有无关的空格,而不是依赖固定的分隔符,让代码能处理所有边界情况。
  4. 代码结构的优化意识 原来以为要写很多 if-else 来判断各种情况,后来发现用双指针 + 循环过滤的方式,能把所有空格和单词的处理统一起来,代码更简洁、更健壮,也更容易维护。
  5. 空间复杂度的思考 这道题的解法用了一个 vector<string> 来存储单词,空间复杂度是 \(O(n)\)。虽然能通过题目,但也让我意识到可以尝试 "原地修改字符串" 的优化思路(比如先反转整个字符串,再反转每个单词,最后去除多余空格),来把空间复杂度降到 \(O(1)\),这对后续的进阶学习很有启发。
相关推荐
无限码力几秒前
阿里算法岗 0530笔试真题 - 寻找满足条件的最优子序列
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试真题·阿里算法题
@小阿宝6 分钟前
机器人正向逆向运动学
算法·机器人
小雨下雨的雨8 分钟前
数独算法与求解器鸿蒙PC Electron框架完成深度解析
javascript·人工智能·算法·游戏·华为·electron·鸿蒙系统
HZ·湘怡11 分钟前
数据结构之排序算法 (1)--插入排序
c语言·数据结构·算法·排序算法
ouliten11 分钟前
[Triton笔记7]融合注意力 (Fused Attention)
人工智能·笔记·算法
开源Z12 分钟前
LeetCode 238 · 除自身以外数组的乘积:左右两遍扫描,不用除法
算法·leetcode
BAGAE23 分钟前
FEC-RS前向纠错编码理论及工程实施研究
c语言·c++·qt·算法·决策树·链表
阿旭超级学得完24 分钟前
Linux基础指令 四(apt,vim,git,cgdb)
linux·服务器·开发语言·数据结构·c++·git·vim
兰令水27 分钟前
leecodecode【状态机DP】【2026.6.9打卡-java版本】
java·开发语言·算法
8Qi834 分钟前
LeetCode 5:最长回文子串(Longest Palindromic Substring)—— 题解
算法·leetcode·职场和发展·动态规划