[LeetCode]151.Reverse Words in a String

简介:

题目

Given an input string, reverse the string word by word.

For example,
Given s = “the sky is blue”,
return “blue is sky the”.

Update (2015-02-12):
For C programmers: Try to solve it in-place in O(1) space.

click to show clarification.

Clarification:
What constitutes a word?
A sequence of non-space characters constitutes a word.
Could the input string contain leading or trailing spaces?
Yes. However, your reversed string should not contain leading or trailing spaces.
How about multiple spaces between two words?
Reduce them to a single space in the reversed string.

思路

两次反转法。这里注意单词之间的多个空格只留一个空格以及去掉前导0和后导0。

代码

/*---------------------------------------
*   日期:2015-05-05
*   作者:SJF0115
*   题目: 151.Reverse Words in a String
*   网址:https://leetcode.com/problems/reverse-words-in-a-string/
*   结果:AC
*   来源:LeetCode
*   博客:
-----------------------------------------*/
#include <iostream>
#include <vector>
using namespace std;

class Solution {
public:
    void reverseWords(string &s) {
        int size = s.size();
        if(size <= 0){
            return;
        }//if
        // 前导0
        int index = 0;
        while(s[index] == ' '){
            ++index;
        }//while
        int left = index;
        // 后导0
        index = size - 1;
        while(s[index] == ' '){
            --index;
        }//while
        int right = index;
        // 连续空格只保留一个
        for(int i = left;i <= right;){
            if(i > left && s[i-1] == ' ' && s[i] == ' '){
                s.erase(i-1,1);
                --right;
            }//if
            else{
                ++i;
            }
        }//for
        // 翻转
        int start = left,end = left;
        for(int i = left;i <= right+1;++i){
            if(i == right+1 || s[i] == ' '){
                Reverse(s,start,end-1);
                ++end;
                start = end;
            }//if
            else{
                ++end;
            }//else
        }//for
        // 整体翻转
        Reverse(s,left,right);
        s = s.substr(left,right - left + 1);
    }
private:
    void Reverse(string &str,int start,int end){
        for(int i = start,j = end;i < j;++i,--j){
            swap(str[i],str[j]);
        }//for
    }
};

int main() {
    Solution solution;
    //string str("   abc    cd     ef ");
    string str("  a   vvv  ");
    solution.reverseWords(str);
    cout<<str<<endl;
}

运行时间

这里写图片描述

代码二

/*---------------------------------------
*   日期:2015-05-05
*   作者:SJF0115
*   题目: 151.Reverse Words in a String
*   网址:https://leetcode.com/problems/reverse-words-in-a-string/
*   结果:AC
*   来源:LeetCode
*   博客:
-----------------------------------------*/
#include <iostream>
#include <algorithm>
using namespace std;

class Solution {
public:
    void reverseWords(string &s) {
        int size = s.size();
        if(size <= 0){
            return;
        }//if
        int index = size - 1;
        string str;
        while(index >= 0){
            // 空格
            while(index >= 0 && s[index] == ' '){
                --index;
            }//while
            if(index < 0){
                break;
            }//if
            if(str.size() != 0){
                str.push_back(' ');
            }//if
            string tmp;
            while(index >= 0 && s[index] != ' '){
                tmp.push_back(s[index]);
                --index;
            }//while
            // 翻转
            reverse(tmp.begin(),tmp.end());
            str.append(tmp);
        }//while
        s = str;
    }
};

int main() {
    Solution solution;
    string str("   abc    cd     ef ");
    //string str(" a  ");
    solution.reverseWords(str);
    cout<<str<<endl;
}

运行时间

这里写图片描述

目录
相关文章
|
算法 C++
【LeetCode】【C++】string OJ必刷题
【LeetCode】【C++】string OJ必刷题
92 0
CF1553B Reverse String(数学思维)
CF1553B Reverse String(数学思维)
57 0
|
11月前
|
机器学习/深度学习 canal NoSQL
从C语言到C++_12(string相关OJ题)(leetcode力扣)
从C语言到C++_12(string相关OJ题)(leetcode力扣)
78 0
|
11月前
|
存储 编译器 Linux
标准库中的string类(中)+仅仅反转字母+字符串中的第一个唯一字符+字符串相加——“C++”“Leetcode每日一题”
标准库中的string类(中)+仅仅反转字母+字符串中的第一个唯一字符+字符串相加——“C++”“Leetcode每日一题”
|
11月前
|
Go 机器学习/深度学习 Rust
Golang每日一练(leetDay0119) 反转字符串I\II Reverse String
Golang每日一练(leetDay0119) 反转字符串I\II Reverse String
169 0
Golang每日一练(leetDay0119) 反转字符串I\II Reverse String
|
Java
Leetcode 467. Unique Substrings in Wraparound String
大概翻译下题意,有个无限长的字符串s,是由无数个「abcdefghijklmnopqrstuvwxy」组成的。现在给你一个字符串p,求多少个p的非重复子串在s中出现了?
77 0
|
算法 索引
【LeetCode】string 类的几道简单题
【LeetCode】string 类的几道简单题
【LeetCode】string 类的几道简单题
LeetCode 438. Find All Anagrams in a String
Given a string s and a non-empty string p, find all the start indices of p's anagrams in s. Strings consists of lowercase English letters only and the length of both strings s and p will not be larger than 20,100. The order of output does not matter.
141 0
LeetCode 438. Find All Anagrams in a String
|
存储
LeetCode 394. Decode String
给定一个经过编码的字符串,返回它解码后的字符串。 编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。 你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。 此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k ,例如不会出现像 3a 或 2[4] 的输入。
113 0
LeetCode 394. Decode String
|
索引
LeetCode 387. First Unique Character in a String
给定一个字符串,找到它的第一个不重复的字符,并返回它的索引。如果不存在,则返回 -1。
164 0
LeetCode 387. First Unique Character in a String

热门文章

最新文章

下一篇
oss创建bucket