LeetCode 151. 翻转字符串里的单词

题目描述

给你一个字符串 s ,逐个翻转字符串中的所有 单词 。

单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。

请你返回一个翻转 s 中单词顺序并用单个空格相连的字符串。

说明:

输入字符串 s 可以在前面、后面或者单词间包含多余的空格。
翻转后单词间应当仅用一个空格分隔。
翻转后的字符串中不应包含额外的空格。

示例1 :

输入:s = "the sky is blue"
输出:"blue is sky the"

示例2 :

输入:s = "  hello world  "
输出:"world hello"
解释:输入字符串可以在前面或者后面包含多余的空格,但是翻转后的字符不能包括。

代码

class Solution {
public:
    string reverseWords(string s) {
        int n;
        vector<string> result;
        n=s.size();
        string ss="";
        string sss="";
        string re="";
        for(int i=0;i<n;i++){
            if((s[i]>='a'&&s[i]<='z')||(s[i]>='A'&&s[i]<='Z')||(s[i]>='0'&&s[i]<='9'))
                 {
                     sss=s[i];
                     ss.append(sss);
                 }
            else {
                if(ss!="")
                    result.push_back(ss);
                ss="";
            }

        }
        if(ss!="")
            result.push_back(ss);
        for(int i=result.size()-1;i>=0;i--){
            re.append(result[i]);
            if(i!=0){
                re.append(1,' ');
            }
        }   
        return re;

    }
};

你可能感兴趣的:(Leetcode,leetcode)