【剑指offer】面试题58 翻转单词顺序列

本文介绍了一道面试题,要求输入一个句子,例如'I am a student.',反转句子中单词的顺序,但单词内的字符顺序不变。通过分析字符串,以空格为边界,将先出现的单词放在后面,实现句子的整体反转。文中提供了C++的解题代码,需要注意C++中单引号和双引号的区别。
摘要由CSDN通过智能技术生成

面试题–【剑指Offer】 题目解答

题目要求

输入一个句子,例如“I am a student.”,反转句子中单词的顺序,标点和字母处理方式一样, 但单词内的字符顺序不变,输出反转后的结果,如“student. a am I”。

解题分析

不同于书上的官方解法,在这里我们巧妙地利用字符串的相加和空格的判断来达到字符串反转的效果!
比较 “I am a student.” 和 “student. a am I”, 你会发现实际上就是把I,am依次放在了字符串的最后(变成am, I),我们按照字符串出现的顺序,以空格分割,先出现的放到最后,次出现的放到倒数第二位,依次遍历字符串,完成转换。

另外本题目是,整体反转,局部不反转(单词不反转),只是用一次stl的reverse函数是不够的,因为他是局部,整体全都反转!!

主要代码c++

class Solution {
public:
    string ReverseSentence(string str) {
        string res,tmp = ""; // res存放最后结果, tmp存放每一个小字符串的结果
        
        for(unsigned int i = 0; i < str.size(); ++i)//无符号类型能保存2倍于有符号类型的正整数数据。
        {
            if(str[i] == ' ')
            {
                 res = " " + tmp + res; // 每一个小块翻转
                 tmp = "";
            }   
            else
                tmp += str[i];
        }
        
        if(tmp.size()) // 因为最后一个小片段没办法用空格判断
            res = tmp + res;
        
        return res;
    }
};

小tips: c++中的 单引号和双引号

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值