superman

聚精会神搞建设 一心一意谋发展
posts - 190, comments - 17, trackbacks - 0, articles - 0
   :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

ZOJ 1068 - P,MTHBGWB

Posted on 2008-03-29 00:35 superman 阅读(236) 评论(0)  编辑 收藏 引用 所属分类: ZOJ
 1 /* Accepted 1068 C++ 00:00.00 868K */
 2 #include <map>
 3 #include <stack>
 4 #include <string>
 5 #include <iostream>
 6 
 7 using namespace std;
 8 
 9 int main()
10 {
11     map <charstring> morse;
12     morse['A'= ".-";
13     morse['B'= "-...";
14     morse['C'= "-.-.";
15     morse['D'= "-..";
16     morse['E'= ".";
17     morse['F'= "..-.";
18     morse['G'= "--.";
19     morse['H'= "....";
20     morse['I'= "..";
21     morse['J'= ".---";
22     morse['K'= "-.-";
23     morse['L'= ".-..";
24     morse['M'= "--";
25     morse['N'= "-.";
26     morse['O'= "---";
27     morse['P'= ".--.";
28     morse['Q'= "--.-";
29     morse['R'= ".-.";
30     morse['S'= "...";
31     morse['T'= "-";
32     morse['U'= "..-";
33     morse['V'= "...-";
34     morse['W'= ".--";
35     morse['X'= "-..-";
36     morse['Y'= "-.--";
37     morse['Z'= "--..";
38     morse['_'= "..--";
39     morse[','= ".-.-";
40     morse['.'= "---.";
41     morse['?'= "----";
42     
43     int n, count = 0; cin >> n;
44     string message;
45     while(cin >> message)
46     {
47         string code;
48         stack <int> len;
49         for(int i = 0; i < message.size(); i++)
50         {
51             code += morse[message[i]];
52             len.push(morse[message[i]].size());
53         }
54         
55         cout << ++count << ':' << ' ';
56         
57         int pos = 0;
58         string ch = "ABCDEFGHIJKLMNOPQRSTUVWXYZ_,.?";
59         while(len.empty() == false)
60         {
61             for(int i = 0; i < 30; i++)
62                 if(morse[ch[i]].size() == len.top())
63                     if(code.find(morse[ch[i]], pos) == pos)
64                     {
65                         cout << ch[i];
66                         break;
67                     }
68             pos += len.top();
69             len.pop();
70         }
71         cout << endl;
72     }
73     
74     return 0;
75 }
76 

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理