• <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)  編輯 收藏 引用
            成人妇女免费播放久久久| 超级碰碰碰碰97久久久久| 国产ww久久久久久久久久| 国产成人香蕉久久久久| 久久综合鬼色88久久精品综合自在自线噜噜| 久久国产AVJUST麻豆| 天堂久久天堂AV色综合| 欧美国产精品久久高清| 99久久中文字幕| 亚洲AV无码久久精品蜜桃| 青春久久| 久久久久久国产精品无码下载| 18禁黄久久久AAA片| 久久久黄片| 91久久香蕉国产熟女线看| 亚洲AV日韩精品久久久久久久| 国产精品亚洲综合专区片高清久久久| 国产A三级久久精品| 99久久这里只精品国产免费| 91精品国产综合久久香蕉| 国产韩国精品一区二区三区久久| 一本色道久久综合| 国产精品久久久久一区二区三区| 99999久久久久久亚洲| 久久综合香蕉国产蜜臀AV| 亚洲AV无码1区2区久久| 偷窥少妇久久久久久久久| 深夜久久AAAAA级毛片免费看| 国产精品成人精品久久久| 99久久免费只有精品国产| 老司机国内精品久久久久| 国产精品18久久久久久vr| 久久66热人妻偷产精品9| 日本久久久久亚洲中字幕| 777午夜精品久久av蜜臀| 亚洲va久久久噜噜噜久久天堂 | 久久青青草原亚洲av无码app | 久久久久亚洲AV无码专区网站| 久久久久久久综合日本亚洲| 777米奇久久最新地址| 久久精品国产精品青草|