• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 183,  comments - 10,  trackbacks - 0
            輸入一個英文句子,翻轉(zhuǎn)句子中單詞的順序,但單詞內(nèi)字符的順序不變。句子中單詞以空格符隔開。為簡單起見,標(biāo)點(diǎn)符號和普通字母一樣處理。
            例如輸入“I am a student.”,則輸出“student. a am I”。

            這個問題在多處曾出現(xiàn)過。大體思路是兩次翻轉(zhuǎn),即先翻轉(zhuǎn)各個單詞,然后將整個句子翻轉(zhuǎn)。也可將兩個翻轉(zhuǎn)順序顛倒過來,先翻轉(zhuǎn)句子,在翻轉(zhuǎn)單詞。
            一種無意義的做法是,先把句子中的每個單詞存放在一個 vector<string> 中,然后反向遍歷輸出。

             1 #include <iostream>
             2 #include <string>
             3 using namespace std;
             4 
             5 void reverseStr(string& s, string::size_type left, string::size_type right)
             6 {
             7     while (left < right)
             8     {        
             9         swap(s[left++], s[right--]);
            10     }
            11 }
            12 
            13 string getReverse(const string& s)
            14 {
            15     if (s.empty())
            16     {
            17         return string("");
            18     }
            19     string ret = s;
            20     string::size_type left, right;
            21     left = s.find_first_not_of(' '0);
            22     right = s.find_first_of(' ', left);
            23     while (right != string::npos)
            24     {
            25         reverseStr(ret, left, right - 1);
            26         left = s.find_first_not_of(' ', right);
            27         right = s.find_first_of(' ', left);
            28     }
            29     if (left != string::npos)
            30     {
            31         reverseStr(ret, left, ret.size() - 1);
            32     }
            33     reverseStr(ret, 0, ret.size() - 1);
            34     return ret;
            35 }
            36 
            37 int main()
            38 {
            39     string s;
            40     while (getline(cin, s))
            41     {
            42         cout << getReverse(s) << endl;
            43     }
            44     return 0;
            45 }
            posted on 2011-04-23 19:26 unixfy 閱讀(1272) 評論(0)  編輯 收藏 引用
            久久伊人五月天论坛| 国产精品狼人久久久久影院| 亚洲国产精品嫩草影院久久| 久久久久亚洲精品男人的天堂 | 久久精品夜色噜噜亚洲A∨| 国产日韩久久免费影院| 欧美精品九九99久久在观看| 国产三级久久久精品麻豆三级| 94久久国产乱子伦精品免费| 一本久久综合亚洲鲁鲁五月天| 久久Av无码精品人妻系列| 激情久久久久久久久久| 无码超乳爆乳中文字幕久久| 中文字幕久久欲求不满| 国产成人精品综合久久久久| 狠狠色伊人久久精品综合网 | 久久精品国产一区二区三区不卡| yy6080久久| 色综合久久中文字幕综合网| 国产精品久久久久aaaa| 亚洲精品美女久久777777| 国产精品伊人久久伊人电影| 好久久免费视频高清| 无码超乳爆乳中文字幕久久 | 成人久久精品一区二区三区| 伊人久久大香线蕉AV一区二区| 亚洲一区中文字幕久久| 777米奇久久最新地址| 久久综合久久综合亚洲| 亚洲欧美日韩精品久久亚洲区 | 少妇无套内谢久久久久| 精品久久久久久无码中文野结衣 | 久久91精品国产91| 国产激情久久久久影院小草 | 久久久噜噜噜久久熟女AA片| 久久笫一福利免费导航 | 色99久久久久高潮综合影院| 99久久久久| 日本高清无卡码一区二区久久| 狠狠久久综合伊人不卡| 亚洲国产精品嫩草影院久久|