JZ44 翻转单词顺序列**

题目描述

牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a student.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?

思路

两步走

  • 先把整体句子翻转
  • 再把单词进行翻转

这样只需要写一个翻转函数(用首尾指针的方法)
在第二步中,需要找到空格的位置;其次,还有什么时候结束的问题,也就是循环结束条件

代码

class Solution {
public:
    string ReverseSentence(string str) {
        ReverseWord(str, 0, str.size() - 1);
        int begin = 0, end = 0;
        while (end<str.size())
        {
            while (str[end] != ' ' && str[end] != '\0')  //找到空格
            {
                end++;
            }
            ReverseWord(str, begin, end - 1);  //翻转单词
            end++; 
            begin = end;   //下一个单词的开始
        }
        return str;

    }

    void ReverseWord(string &res, int begin, int end)  //整体翻转
    {
        char temp;
        while (begin < end)
        {
            temp = res[begin];
            res[begin] = res[end];
            res[end] = temp;
            begin++;
            end--;
        }
    }
};
全部评论

相关推荐

今天 10:23
已编辑
湖南师范大学 计调
太久没更新,前几天看到一条评论,说“牛客就是当年那群做题区毕业了开始找工作还收不住那股味”的群体。字里行间透着居高临下的评判,不是,他该不会以为自己很幽默?很犀利吧?作为在牛客混了不算短日子的用户,我感到的不只是被冒犯,更是一种深刻的悲哀——这种以“松弛感”为名,对另一种生存策略的轻蔑,颇有一种自己考不上大学早早出来混社会,嘲笑考上大学的人是书呆子,然后大言不惭地说:死读书有什么用,人脉和资源才是硬道理。我不知道说这个话的人,手头究竟握着多少真正管用的人脉与资源,也不知道他这么傲慢地说出“那股味”的时候,是站在哪一个巨人的肩膀上,才能如此“松弛从容”地俯视众生,还能品评出别人身上“没收住”的余...
淬月星辉:这种评论把正常的努力扭曲成卷😂,说白了就是自己不努力,看着身边努力的人一个个都事业有成了,自己的心里开始不平衡了,就发这种酸言酸语。牛客可以说是我用过那么多平台里社区氛围最好的论坛了,用了大半年了,基本上没见过有人吵架的,都是在互帮互助提建议,帮忙看简历的,帮忙选offer的,帮忙指点学习路线的,分享工作经验和趣事的,我觉得这才是互联网该有的样子。
点赞 评论 收藏
分享
01-07 11:46
Java
如图:也是让我遇到逆天公司了,实习生是按天给工资,不忙直接强制休假了
baskly:公司为北京超图软件股份有限公司武汉分公司,明年公司应该会招新实习生,刷到的小伙伴快跑
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务