• <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

            第一個只出現一次的字符

            一個字符串中,查找其中第一個只出現一次的字符。
            這里建設這個字符串中的字符可以使英文大小寫字符也可以是數字字符。

            http://www.shnenglu.com/jake1036/archive/2011/05/17/146542.html

            解決方案是:
            用 map 記錄每個字符的出現次數,以及第一次出現的索引。
            然后遍歷 map ,找到出現 1 次且索引最小的那個字符。

             1 #include <iostream>
             2 #include <string>
             3 #include <map>
             4 using namespace std;
             5 
             6 char findHeadOnce(const string& s)
             7 {
             8     map<charint> times;
             9     map<charint> indexes;
            10     for (string::size_type i = 0; i != s.size(); ++i)
            11     {
            12         ++times[s[i]];
            13         if (times[s[i]] == 1)
            14         {
            15             indexes[s[i]] = i;
            16         }
            17     }
            18     int idx = s.size();
            19     for (map<charint>::const_iterator cit = indexes.begin(); cit != indexes.end(); ++cit)
            20     {
            21         if (times[cit->first] == 1 && idx > cit->second)
            22         {
            23             idx = cit->second;
            24         }
            25     }
            26     if (idx < s.size())
            27     {
            28         return s[idx];
            29     }
            30     else
            31     {
            32         return '*';
            33     }
            34 }
            35 
            36 int main()
            37 {
            38     string s;
            39     while (cin >> s)
            40     {
            41         cout << findHeadOnce(s) << endl;
            42     }
            43 }

             


            posted on 2011-07-22 16:21 unixfy 閱讀(313) 評論(0)  編輯 收藏 引用
            99精品国产免费久久久久久下载 | 国产精品青草久久久久福利99 | 久久伊人五月天论坛| 婷婷久久精品国产| 日产精品久久久久久久| 久久久久99精品成人片试看| 久久免费小视频| 欧美日韩精品久久久免费观看| 韩国免费A级毛片久久| 久久夜色撩人精品国产小说| 色综合久久久久久久久五月| 国产免费久久精品丫丫| 男女久久久国产一区二区三区| 久久精品国产只有精品66| 久久久无码精品亚洲日韩按摩| 久久天天日天天操综合伊人av | 久久九九亚洲精品| 亚洲精品无码久久久久久| 91精品国产色综久久| 久久综合香蕉国产蜜臀AV| 四虎亚洲国产成人久久精品| 99精品久久久久久久婷婷| 亚洲AV无码1区2区久久| 亚洲婷婷国产精品电影人久久 | 久久精品亚洲男人的天堂| 久久中文字幕一区二区| 久久精品人人做人人妻人人玩| 久久99热这里只有精品66| 亚洲国产成人精品无码久久久久久综合 | 狠狠色丁香久久婷婷综合图片| 一本大道久久a久久精品综合| 人妻无码αv中文字幕久久琪琪布| 国内精品伊人久久久影院| 亚洲国产精品综合久久网络| 人妻系列无码专区久久五月天| 91久久九九无码成人网站| 国产精品伦理久久久久久| 久久青青草原精品国产软件| 亚洲精品无码专区久久同性男| 久久WWW免费人成—看片| 久久精品夜色噜噜亚洲A∨|