宋体数据2013编程之美全国挑战赛资格赛之传话游戏

本篇文章笔者在广东逛街的时候突然想到的...最近就有想写几篇关于宋体数据的博客,所以回家到之后就奋笔疾书的写出来发表了

    

间时制限: 1000ms 内存制限: 256MB

    

描述

    

Alice和Bob还有其他几位好朋友在一起玩传话游戏。这个游戏是这样停止的:首先,有所游戏者按序顺站成一排,Alice站第一名,Bob站最后一名。然后,Alice想一句话悄悄告知第二位游戏者,第二位游戏者又悄悄地告知第三位,第三位又告知第四位……以此类推,直到倒数第二位告知Bob。两位游戏者在传话中,不能让其他人听到,也不能用使肢体作动来释解。最后,Bob把他所听到的话告知大家,Alice也把她本来所想的话告知大家。 

    

由于传话中程过可能涌现一些偏差,游戏者越多,Bob最后听到的话就与Alice所想的越不同。Bob听到的话往往会成变一些很搞笑的货色,所以大家玩得乐此不疲。经过几轮游戏后,Alice注意到在两人传话中,有些汇词往往会错误地成变其他特定的汇词。Alice经已搜集到了这样的一个汇词转化的列表,她想道知她的话传到Bob时会成变什么模样,请你写个序程来帮助她。

    

入输

    

入输括包多组数据。第一行是数整 T,表现有多少组测试数据。每组数据第一行括包两个数整 N 和 M,别分表现游戏者的数量和单词转化列表长度。随后有 M 行,每行括包两个用空格离隔的单词 a 和 b,表现单词 a 在传话中一定会成变 b。入输数据保障没有重复的 a。最后一行括包若干个用单个空格离隔的单词,表现Alice所想的句子,句子总长不超越100个字符。有所单词都只括包小写字母,并且长度不超越20,同一个单词的不同时态被认为是不同的单词。你可以假设不在列表中的单词永久不会变更。

    

出输

    

对于每组测试数据,独自出输一行“Case #c: s”。其中,c 为测试数据编号,s 为Bob所听到的句子。s 的格式与入输数据中Alice所想的句子格式同相。

    

数据围范

    

1 ≤ T ≤ 100

    

小数据:2 ≤ N ≤ 10, 0 ≤ M ≤ 10 

    

大数据:2 ≤ N ≤ 100, 0 ≤ M ≤ 100 

    

样例入输

  1. 4 3 
  2. ship sheep 
  3. sinking thinking 
  4. thinking sinking 
  5. the ship is sinking 
  6. 10 5 
  7. tidy tiny 
  8. tiger liar 
  9. tired tire 
  10. tire bear 
  11. liar bear 
  12. a tidy tiger is tired 

    

样例出输

  1. Case #1: the sheep is thinking 
  2. Case #2: a tiny bear is bear 

    

 

    

代码如下:
  1. #include <cstdio> 
  2. #include <cstring> 
  3. #include <cmath> 
  4. #include <string> 
  5. #include <iostream> 
  6. #include <map> 
  7.   
  8. using namespace std; 
  9.   
  10. map<string,string> mm; 
  11. char s1[30],s2[30],s[110],*p; 
  12. int t,m,n; 
  13.   
  14. void solve() 
  15.     int i; 
  16.     string str; 
  17.     str=p; 
  18.     for(i=1;i<n;i++)  
  19.     { 
  20.         if(mm.count(str)) 
  21.             str=mm[str]; 
  22.         else 
  23.             break
  24.     }  
  25.     cout<<str; 
  26.   
  27. int main() 
  28.     int i,cnt;scanf("%d%*c",&t); 
  29.     for(cnt=1;cnt<=t;cnt++) 
  30.     { 
  31.         mm.clear(); 
  32.         scanf("%d %d%*c",&n,&m); 
  33.         for(i=0;i<m;i++) 
  34.         { 
  35.             scanf("%s %s%*c",s1,s2); 
  36.             mm[s1]=s2; 
  37.         } 
  38.         gets(s); 
  39.         printf("Case #%d: ",cnt); 
  40.         p=strtok(s," "); 
  41.         solve(); 
  42.         while((p=strtok(NULL," "))) 
  43.         { 
  44.             cout<<" "
  45.             solve(); 
  46.         } 
  47.         cout<<endl; 
  48.     } 
  49.   
  50.     return 0; 

    

    

另一组代码:
    每日一道理
生活的无奈,有时并不源于自我,别人无心的筑就,那是一种阴差阳错。生活本就是矛盾的,白天与黑夜间的距离,春夏秋冬之间的轮回,于是有了挑剔的喜爱,让无奈加上了喜悦的等待。
  1. #include <stdio.h> 
  2. #include <cstring> 
  3. #include <vector> 
  4. #include <map> 
  5.   
  6. using namespace std; 
  7.   
  8.   
  9. //字符串分割数函 
  10.  std::vector<std::string> split(std::string str,std::string pattern) 
  11.  { 
  12.      std::string::size_type pos; 
  13.      std::vector<std::string> result; 
  14.      str+=pattern;//扩展字符串以便方作操 
  15.      int size=str.size(); 
  16.   
  17.      for(int i=0; i<size; i++) 
  18.      { 
  19.          pos=str.find(pattern,i); 
  20.          if(pos<size) 
  21.          { 
  22.              std::string s=str.substr(i,pos-i); 
  23.              result.push_back(s); 
  24.              i=pos+pattern.size()-1; 
  25.          } 
  26.      } 
  27.      return result; 
  28.  } 
  29.   
  30. void Update(vector<string> & str,map<string,string> & w_map) 
  31.     map<string,string>::iterator it; 
  32.     for(int i=0;i<str.size();i++) 
  33.     { 
  34.         it = w_map.find(str[i]); 
  35.         if(it != w_map.end()) 
  36.         { 
  37.             str[i]=it->second; 
  38.         } 
  39.     } 
  40.   
  41. int main() 
  42.     int T; 
  43.   
  44.     while(scanf("%d",&T) == 1) 
  45.     { 
  46.         for(int x=1;x<=T;x++) 
  47.         { 
  48.             int N,M; 
  49.             map<string,string> words_map; 
  50.             string s1,s2; 
  51.             string srcWords,tgtWords; 
  52.   
  53.             scanf("%d%d",&N,&M); 
  54.             for(int i=1;i<=M;i++) 
  55.             { 
  56.                 cin>>s1>>s2; 
  57.                 words_map.insert(make_pair(s1,s2)); 
  58.             } 
  59.             cin.get();//吃掉上一行换行符 
  60.             getline(cin,srcWords,'\n'); 
  61.             vector<string> singleWord = split(srcWords," "); 
  62.   
  63.   
  64.             for(int i=1;i<=N-1;i++) 
  65.             { 
  66.                 Update(singleWord,words_map); 
  67.             } 
  68.             printf("Case #%d: ",x); 
  69.             for(int i=0;i<singleWord.size()-1;i++) 
  70.                 cout<<singleWord[i]<<" "
  71.             cout<<singleWord[singleWord.size()-1]<<endl; 
  72.         } 
  73.   
  74.     } 
  75.     return 0; 

    

文章结束给大家分享下程序员的一些笑话语录: 开发时间
  项目经理: 如果我再给你一个人,那可以什么时候可以完工?程序员: 3个月吧!项目经理: 那给两个呢?程序员: 1个月吧!
项目经理: 那100呢?程序员: 1年吧!
项目经理: 那10000呢?程序员: 那我将永远无法完成任务.

posted @ 2013-04-30 18:19  xinyuyuanm  阅读(195)  评论(0编辑  收藏  举报