[力扣题解] 151. 反转字符串中的单词

题目:151. 反转字符串中的单词

思路

代码

Method 1,Me

class Solution {
public:
    string reverseWords(string s) {
        int i, start;
		// Step 1
        for(i = 0; i < s.size() - 1; i++)
        {
            if(s[i] == ' ' && s[i + 1] == ' ')
            {
                s.erase(i + 1, 1);
                i--;
            }
        }
		
		// Step 2
        if(!s.empty() && s[0] == ' ')
        {
            s.erase(s.begin());
        }
        if(!s.empty() && s[s.size() - 1] == ' ')
        {
            s.erase(s.end() - 1);
        }
		
		// Step 3
        reverse(s.begin(), s.end());
		
		// Step 4
        start = 0;
        for(i = 0; i <= s.size(); i++)
        {
            if(i == s.size() || s[i] == ' ')
            {
                reverse(s.begin() + start, s.begin() + i);
                start = i + 1;
            }
        }
        return s;
    }
};    

注意去除头部和尾部空格的代码要放在去除重复空格的后面;

Method 2 : 双指针法

void removeExtraSpaces(string& s) 
{
    int slowIndex = 0, fastIndex = 0; // 定义快指针,慢指针
    // 去掉字符串前面的空格
    while (s.size() > 0 && fastIndex < s.size() && s[fastIndex] == ' ') 
    {
        fastIndex++;
    }
    for (; fastIndex < s.size(); fastIndex++) 
    {
        // 去掉字符串中间部分的冗余空格
        if (fastIndex - 1 > 0
                && s[fastIndex - 1] == s[fastIndex]
                && s[fastIndex] == ' ') 
        {
            continue;
        } 
        else 
        {
            s[slowIndex++] = s[fastIndex];
        }
    }
    if (slowIndex - 1 > 0 && s[slowIndex - 1] == ' ') 
    { // 去掉字符串末尾的空格
        s.resize(slowIndex - 1);
    } 
    else 
    {
        s.resize(slowIndex); // 重新设置字符串大小
    }
}

去除多余空格时间复杂度:O(n);

注释

Me :自己写的

相关推荐

  1. [题解] 151. 字符串单词

    2024-06-05 19:37:18       28 阅读
  2. -151. 字符串单词

    2024-06-05 19:37:18       67 阅读
  3. 字符串单词151

    2024-06-05 19:37:18       36 阅读
  4. 每日一题 --- 字符串单词[][Go]

    2024-06-05 19:37:18       40 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-05 19:37:18       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-05 19:37:18       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-05 19:37:18       82 阅读
  4. Python语言-面向对象

    2024-06-05 19:37:18       91 阅读

热门阅读

  1. Python笔记 - *args和**kwargs

    2024-06-05 19:37:18       32 阅读
  2. linux笔记

    2024-06-05 19:37:18       31 阅读
  3. 【C语言从入门到入土】第一章前言

    2024-06-05 19:37:18       29 阅读
  4. 洛谷 P8741 [蓝桥杯 2021 省 B] 填空问题 题解

    2024-06-05 19:37:18       33 阅读
  5. 2024华为OD机试真题-机场航班调度-C++(C卷D卷)

    2024-06-05 19:37:18       27 阅读
  6. 【学习笔记】TypeScript

    2024-06-05 19:37:18       23 阅读
  7. 力扣283题:移动零(快慢指针)

    2024-06-05 19:37:18       34 阅读
  8. for循环

    2024-06-05 19:37:18       31 阅读
  9. 智能网联汽车翻译

    2024-06-05 19:37:18       18 阅读