poj 2121 && poj 2403

题目:http://poj.org/problem?id=2121

很很简单的题,权当用map 做着玩吧,就是给出英文的数,然后让你转换成数字,注意当是 百,千,百万的时候的处理,不为别的,就为了那个打表,打的眼晕,最后还是打错了,交了两次才发现,汗

View Code
 1 #include<iostream>
 2 #include<sstream>
 3 #include<cstdio>
 4 #include<cstring>
 5 #include<algorithm>
 6 #include<string>
 7 #include<vector>
 8 #include<map>
 9 #include<queue>
10 #include<stack>
11 #include<cmath>
12 #include<set>
13 #define N 5010
14 #define inf 100000000
15 #define _clr(a,val) (a,val,sizeof(a))
16 #define Min(x, y)   x < y ? x : y
17 #define Max(x, y)   x < y ? y : x
18 
19 using namespace std;
20 
21 typedef long long ll;
22 
23 char str[N];
24 map<string,int>ma;
25 void init()
26 {
27     ma["zero"] = 0, ma["one"] = 1, ma["two"] = 2;
28     ma["three"] = 3, ma["four"] = 4, ma["five"] = 5;
29     ma["six"] = 6, ma["seven"] = 7, ma["eight"] = 8;
30     ma["nine"] = 9, ma["ten"] = 10, ma["eleven"] = 11;
31     ma["twelve"] = 12, ma["thirteen"] = 13, ma["fourteen"] = 14;
32     ma["fifteen"] = 15, ma["sixteen"] = 16, ma["seventeen"] = 17;
33     ma["eighteen"] = 18, ma["nineteen"] = 19, ma["twenty"] = 20;
34     ma["thirty"] = 30, ma["forty"] = 40, ma["fifty"] = 50;
35     ma["sixty"] = 60, ma["seventy"] = 70, ma["eighty"] = 80;
36     ma["ninety"] = 90;
37     ma["hundred"] = 100, ma["thousand"] = 1000, ma["million"] = 1000000;
38 }
39 int main()
40 {
41     //freopen("data.txt","r",stdin);
42     init();
43     while(gets(str))
44     {
45         ll sum = 0;
46         ll tsum = 0;
47         if(!strcmp(str,"")) break;
48         istringstream s(str);
49         while(s >> str)
50         {
51             //cout<<"str = "<<str<<endl;
52             if(!strcmp(str,"negative")) printf("-");
53             if(strcmp(str,"million") && strcmp(str,"thousand") && strcmp(str,"hundred") && strcmp(str,"zero")) sum += ma[str];
54             else if(!strcmp(str,"hundred") || !strcmp(str,"zero")) sum *= ma[str];
55             else if(!strcmp(str,"thousand"))
56             {
57                 tsum += sum * 1000, sum = 0;
58             }
59             else if(!strcmp(str,"million"))
60             {
61                 tsum += sum * 1000000, sum = 0;
62             }
63         }
64         //printf("%I64d\n",tsum + sum);
65         cout<<(tsum + sum)<<endl;
66     }
67     return 0;
68 }

题目:http://poj.org/problem?id=2403

比上个还简单的题,先是给出 N 个单词,每个单词对应一个权值,下面给出M串很长的字符串,让你统计在每个字符串里出现的单词的权值总和

View Code
 1 #include<iostream>
 2 #include<sstream>
 3 #include<cstdio>
 4 #include<cstring>
 5 #include<algorithm>
 6 #include<string>
 7 #include<vector>
 8 #include<map>
 9 #include<queue>
10 #include<stack>
11 #include<cmath>
12 #include<set>
13 #define N 5010
14 #define inf 100000000
15 #define _clr(a,val) (a,val,sizeof(a))
16 #define Min(x, y)   x < y ? x : y
17 #define Max(x, y)   x < y ? y : x
18 
19 using namespace std;
20 
21 typedef long long ll;
22 
23 char str[N];
24 
25 map<string,int>ma;
26 
27 int main()
28 {
29     //freopen("data.txt","r",stdin);
30     int n,m;
31     int x;
32     while(scanf("%d%d",&n,&m) != EOF)
33     {
34         for(int i = 0; i < n; i++)
35         {
36             cin>>str>>x;
37             ma[str] = x;
38         }
39         while(m--)
40         {
41             ll sum = 0;
42             while(gets(str))
43             {
44                 if(!strcmp(str,".")) break;
45                 istringstream s(str);
46                 while(s >> str)
47                 {
48                     sum += ma[str];
49                 }
50             }
51             cout<<sum<<endl;
52         }
53     }
54     return 0;
55 }

 

posted @ 2012-08-18 11:28  AC_Girl  阅读(174)  评论(0编辑  收藏  举报