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

            ivy-jie

            progress ...

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              9 Posts :: 41 Stories :: 6 Comments :: 0 Trackbacks

            字符串替換
            題目描述:請編寫程序,根據(jù)指定的對應(yīng)關(guān)系,把一個文本中的字符串替換成另外的字符串。

            輸入數(shù)據(jù):程序讀入已被命名為text.txt和dict.txt的兩個輸入數(shù)據(jù)文本文件,text.txt為一個包含大量字符串(含中文)的文本,以whitespace為分隔符;dict.txt為表示字符串(s1)與字符串(s2)的對應(yīng)關(guān)系的另一個文本(含中文),大約在1萬行左右,每行兩個字符串(即s1和s2),用一個\t或空格分隔。dict.txt中各行的s1沒有排序,并有可能有重復(fù),這時以最后出現(xiàn)的那次s1所對應(yīng)的s2為準(zhǔn)。text.txt和dict.txt中的每個字符串都可能包含除whitespace之外的任何字符。text.txt中的字符串必須和dict.txt中的某s1完全匹配才能被替換。(為便于調(diào)試,您可下載測試text.txt和dict.txt文件,實際運行時我們會使用不同內(nèi)容的輸入文件。)

            輸出數(shù)據(jù):在標(biāo)準(zhǔn)輸出上打印text.txt被dict.txt替換后了的整個文本。

            評分標(biāo)準(zhǔn):程序輸出結(jié)果必須正確,內(nèi)存使用越少越好,程序的執(zhí)行時間越快越好。PS:c_str()返回一個它自己的使用內(nèi)存的地址(一個C-STYLE的string——)  
              會自動給最后添上一個'\0'結(jié)束符號  

            #include<iostream>

            #include<fstream>

            #include<string>

            #include<map>

            using namespace std;

            map<string,string>dic;

            int main()

            {

                   string s,a,b;

                   char c;

                   fstream file("dict.txt");

                   while (file>>a>>b)

                          dic[a]=b;

                   file.close();

                   freopen("text.txt","r",stdin);

                   while (scanf("%c",&c)+1)

                   {

                          if (c&128)

                          {

                                 s+=c;

                                 scanf("%c",&c);

                          }

                          if ((c&128)==0&&isspace(c))

                          {

                                 if (!s.empty())

                                        if (dic[s]!="")

                                               printf("%s",dic[s].c_str());

                                        else

                                               printf("%s",s.c_str());

                                 printf("%c",c);

                                 s="";

                          }

                          else

                                 s+=c;

                   }

                   if (!s.empty())

                          if (dic[s]!="")

                                 printf("%s",dic[s].c_str());

                          else

                                 printf("%s",s.c_str());

                   return 0;

            }

            posted on 2009-05-19 00:19 ivy-jie 閱讀(260) 評論(0)  編輯 收藏 引用 所屬分類: arithmetic
            色综合久久天天综线观看| 婷婷久久精品国产| 久久艹国产| 亚洲综合伊人久久大杳蕉| 93精91精品国产综合久久香蕉| 亚洲国产精品成人久久蜜臀| 成人妇女免费播放久久久| 久久免费99精品国产自在现线| 亚洲成色WWW久久网站| 久久久久亚洲AV无码去区首| 精品无码久久久久久尤物| 亚洲国产成人乱码精品女人久久久不卡 | 狠狠人妻久久久久久综合蜜桃| 99久久国产精品免费一区二区| 国产精品九九久久免费视频| 亚洲AV日韩精品久久久久久久| 久久久久久一区国产精品| 99久久精品午夜一区二区| 婷婷久久五月天| 久久久久亚洲av成人无码电影 | AV无码久久久久不卡蜜桃| 国产精品内射久久久久欢欢| 麻豆亚洲AV永久无码精品久久| 亚洲国产成人精品女人久久久 | 久久精品国产99久久无毒不卡| 久久国产AVJUST麻豆| 久久国产视频99电影| 国产精品一区二区久久精品无码| 72种姿势欧美久久久久大黄蕉| 久久人人爽人人爽人人片av麻烦 | 色综合久久久久久久久五月| 久久久亚洲裙底偷窥综合| 噜噜噜色噜噜噜久久| 老男人久久青草av高清| 久久久这里有精品| 一本色道久久HEZYO无码| 亚洲熟妇无码另类久久久| 亚洲国产精品久久久天堂| 色欲综合久久躁天天躁蜜桃| 亚洲国产另类久久久精品黑人 | 国产99精品久久|