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

建议:这道题目基本把 刚刚做过的字符串操作 都覆盖了,不过就算知道解题思路,本题代码并不容易写,要多练一练。 题目链接: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)\),这对后续的进阶学习很有启发。
相关推荐
先吃饱再说2 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰5 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术6 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六9 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术10 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize11 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营1 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC2 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode