浪迹天涯

唯有努力...
努力....再努力...

字符串替换

字符串替换
题目描述:请编写程序,根据指定的对应关系,把一个文本中的字符串替换成另外的字符串。

输入数据:程序读入已被命名为text.txt和dict.txt的两个输入数据文本文件,text.txt为一个包含大量字符串(含中文)的文本,以whitespace为分隔符;dict.txt为表示字符串(s1)与字符串(s2)的对应关系的另一个文本(含中文),大约在1万行左右,每行两个字符串(即s1和s2),用一个\t或空格分隔。dict.txt中各行的s1没有排序,并有可能有重复,这时以最后出现的那次s1所对应的s2为准。text.txt和dict.txt中的每个字符串都可能包含除whitespace之外的任何字符。text.txt中的字符串必须和dict.txt中的某s1完全匹配才能被替换。(为便于调试,您可下载测试text.txt和dict.txt文件,实际运行时我们会使用不同内容的输入文件。)

输出数据:在标准输出上打印text.txt被dict.txt替换后了的整个文本。

评分标准:程序输出结果必须正确,内存使用越少越好,程序的执行时间越快越好。

#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 2008-01-04 11:36 浪迹天涯 阅读(1755) 评论(0)  编辑 收藏 引用 所属分类: C++


只有注册用户登录后才能发表评论。
【推荐】超50万行VC++源码: 大型组态工控、电力仿真CAD与GIS源码库
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2008年1月>
303112345
6789101112
13141516171819
20212223242526
272829303112
3456789

导航

统计

常用链接

留言簿(22)

随笔分类(30)

随笔档案(29)

文章分类

搜索

积分与排名

最新评论

阅读排行榜

评论排行榜