• 宋体数据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呢?程序员: 那我将永远无法完成任务.

  • 相关阅读:
    Jmeter非GUI、GUI模式压测生成测试报告
    测试轮播banner
    Jmeter如何监控服务器CPU、内存、i/o等资源
    java基础(三)
    用python从符合一定格式的txt文档中逐行读取数据并按一定规则写入excel(openpyxl支持Excel 2007 .xlsx格式)
    L2-011. 玩转二叉树
    L2-010. 排座位
    L2-008. 最长对称子串
    L2-009. 抢红包
    L2-006. 树的遍历
  • 原文地址:https://www.cnblogs.com/xinyuyuanm/p/3052257.html
Copyright © 2020-2023  润新知