字符串替換
題目描述:請編寫程序,根據(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;
}