leetcode 151反转字符串如何原地去除多余空格

题目:https://leetcode.cn/problems/reverse-words-in-a-string/description/
完整题解:https://leetcode.cn/problems/reverse-words-in-a-string/solutions/2611893/chu-li-kong-ge-ku-han-shu-reversefan-zhu-bioo
思路来自代码随想录,对其中的除去多余空格做详细解释
本题的输入数据会给很多多余空格,我们需要用双指针遍历只留下每个单词间的一个空格就可以了

        int slow=0;
        int fast=0;
        for(;fast

** 重点在于理解if(slow!=0)什么时候生效**
当快指针遍历到非空字母的时候,要往slow的位置放

  1. 当刚刚开始遍历时,slow==0,遇到字母直接放入位置,不添加空格,消除字符串开头可能有的多余空格
  2. 用while遍历一整个单词,此时slow已经不等于0,而到了单词的下一个位置
  3. 此时快指针又遍历到字母(非空格)时,需要手动添加一个空格,if(slow!=0) { s[slow++]=' '; }此时就执行操作添加一个空格,slow又指向空格的下一个位置,方便后续操作

清楚多余空格后要resize s,不然后面的元素会影响结果

你可能感兴趣的:(leetcode刷题笔记,leetcode,算法,职场和发展,字符串)