zoukankan      html  css  js  c++  java
  • [LeetCode] Reverse Words in a String

    Given an input string, reverse the string word by word.

    For example,
    Given s = "the sky is blue",
    return "blue is sky the".

    Update (2015-02-12):
    For C programmers: Try to solve it in-place in O(1) space.

    click to show clarification.

    Clarification:
    • What constitutes a word?
      A sequence of non-space characters constitutes a word.
    • Could the input string contain leading or trailing spaces?
      Yes. However, your reversed string should not contain leading or trailing spaces.
    • How about multiple spaces between two words?
      Reduce them to a single space in the reversed string.
    Hide Tags
     String
     
    分析:
    如果单词之间遇到多个空格,只能返回一个,而且首尾不能有单词,并且对C语言程序员要求空间复杂度为O(1),所以我们只能对原字符串s之间做修改,而不能声明新的字符串。
     
    第一步:反正整个字符串
    第二部:反正单个word
    第三部:将翻转好的word放到合适的位置,这里合适的位置是指前面的不包含space的位置。
    writePos  标记合适的位置,也就是将要写入的位置。
    第四部:改变字符串大小
     
    
    
    另外,我们在最后压入了一个space,是为了最后的word可以统一处理。


     注意这段code,是为了处理整个字符串都是space的情况。
                if( writePos > 0) //remove the latest space
                    s.resize(writePos - 1);
                else
                    s.resize(0);//the str only contains space

    总之,此题是一道好体,题小乾坤大,很多细节需要处理。

     
     
    AC code:
    class Solution {
        private:
            void reverseWord(string &s, int left, int right)
            {
                char tmp;
                while(left < right)
                {
                    tmp = s[left];
                    s[left] = s[right];
                    s[right] = tmp;
                    left++;
                    right--;
                }
            }
        public:
            void reverseWords(string &s) {
                if(s.size() == 0)
                    return;
    
                //reverse all words
                reverseWord(s, 0, s.size() - 1);
    
                s.push_back(' ');//inorder to handler the latest part
                int size = s.size();
    
                int writePos = 0;//position which will be written
    
                int left = 0, right = 0;
                for(int i = 0; i < size; i++)
                {
                    //convert multiple spaces to one space
                    if(s[i] != ' ')
                    {
                        if(i == 0 || s[i-1] == ' ')
                        {
                            left = i;
                            right = i;
                        }
                        else
                            right ++;
                    }
                    else //if (s[i] == ' ')
                    {
                        if(i > 0 && s[i-1] != ' ')
                        {
                            //cout << "left	" << left << endl;
                            //cout << "right	" << right<< endl;
                            reverseWord(s, left, right);
    
                            //move the part to writePos
                            // it means memmove
                            while(left <= right)
                            {
                                s[writePos++] = s[left++];
                            }
                            s[writePos++] = ' ';//add space after the word
                        }
                    }
                }
    
                if( writePos > 0) //remove the latest space
                    s.resize(writePos - 1);
                else
                    s.resize(0);//the str only contains space
            }
    };
  • 相关阅读:
    [ZT]SAP ECC5.0 Working Log TO 2008.5.26
    VS错误:Lc.exe 已退出错误 返回代码 1
    如何实现两个数据库的同步?
    sp_configure 'max server memory'
    [轉]中国油价世界最高 是美国7倍!
    C#WinForm App自动更新(Live Update)架构
    利用批處理自動在異地備份數據庫
    18种根据屏幕字段查找潜在数据的技巧
    [ZT]2008年到校园招聘各企业待遇曝光
    吉祥物由于具有商业气息,所以历届奥运会吉祥物都没有出场。
  • 原文地址:https://www.cnblogs.com/diegodu/p/4624932.html
Copyright © 2011-2022 走看看