码迷,mamicode.com
首页 > 其他好文 > 详细

剑指OFFER 翻转单词顺序列

时间:2020-01-13 17:50:05      阅读:88      评论:0      收藏:0      [点我收藏+]

标签:str   ++   split   string   enc   eve   tac   new   ring   

剑指OFFER 翻转单词顺序列

思路都是先把一个个单词提取出来,对所有单词进行倒序,

c++

class Solution {
public:
    string ReverseSentence(string str) {
        if(str.size()==0)return string("");
        stack<string> s;
        string word;
        string res;
        int str_size = str.size();
        for(int i=0;i<str_size;i++)
        {
            if(str[i]==' ' || i == str_size-1)
            {
                if(i == str_size - 1)
                {
                    word += str[i];
                }
                s.push(word);
                word.clear();
                continue;
            }
            word += str[i];
        }
        while(!s.empty())
        {
            res += s.top() + ' ';
            s.pop();
        }
        
        
        res.erase(res.size()-1);//去掉后面的空格

        return res;
    }
};

python

# -*- coding:utf-8 -*-
class Solution:
    def ReverseSentence(self, s):
        # write code here
        words = s.split(' ');
        print words
        res = ""
        new_words = words[::-1]
        for word in new_words:
            res = res + " " + word
        res = res[1:]
        return res

剑指OFFER 翻转单词顺序列

标签:str   ++   split   string   enc   eve   tac   new   ring   

原文地址:https://www.cnblogs.com/virgildevil/p/12188389.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!