zoukankan      html  css  js  c++  java
  • 翻转单词顺序列表

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

    思路:

    考查的核心依旧是字符串的翻转
    思路就是先将整个字符串进行翻转,然后再对每个单词进行翻转

    class Solution {
    public:
        string ReverseSentence(string str) {
            int len = str.size();
            if(str[0] == ' ')
                return str;
            reverse(str,0,len-1);
            for(int l = 0,r = 0;r <= len;)
            {
                if(r<len&&str[r] != ' ')
                    r++;
                else
                {
                    reverse(str,l,r-1);
                    l = ++r;
                }
            }
            return str;
        }
        void reverse(string &str,int left,int right)
        {
            for(int i=  left,j = right;i<=left + (right-left)/2;)
            {
                swap(str[i++],str[j--]);
            }
        }
    };
    

    在牛客提交反馈回来的结果中,报如下错误

    那是因为输出结果末尾多了一个空格引起的错误,因此在整个字符串翻转之前,需要判断第一个字符是否为空字符

     if(str[0] == ' ')
                return str;
    
  • 相关阅读:
    九九乘法表
    判断and ,or
    格式化输出
    标志位
    循环
    ECMA-262规范定义的七种错误类型
    主流浏览器内核
    代理服务器(理解篇)
    前端常用词汇整理
    LeetCode 451. 根据字符出现频率排序
  • 原文地址:https://www.cnblogs.com/whiteBear/p/12626637.html
Copyright © 2011-2022 走看看