首页 > 其他 > 详细

HDU - 1243 - 反恐训练营

时间:2014-02-28 18:16:25      阅读:401      评论:0      收藏:0      [点我收藏+]

先上题目:

反恐训练营

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 2783    Accepted Submission(s): 634


Problem Description
当今国际反恐形势很严峻,特别是美国“9.11事件”以后,国际恐怖势力更是有恃无恐,制造了多起骇人听闻的恐怖事件。基于此,各国都十分担心恐怖势力会对本国社会造成的不稳定,于是纷纷在本国的军队、警察队伍中开展了反恐训练。作为反恐立场坚定的大国,中国也十分重视在人民解放军、武装警察部队、人民警察队伍中反恐训练,还专门成立了反恐特警队。

炜炜是反恐特警队的一名新队员,现在正在接受培训。这几天刚好是射击训练第二阶段——实弹应变训练的日子,此前的第一阶段里,炜炜经过努力,已经将自己训练成为一个百发百中的神抢手了!这次,他将背着国产最新型12.7mm重型狙击枪进行训练比赛。

这次训练比赛的规则是这样的:

1、每个队员从出发点开始,沿着一条唯一的笔直道路跑直到终点,途中不允许往回跑,否则将被取消比赛资格。
2、出发前,每个队员的枪膛内都被装了顺序一样的、用小写英文字母标明类型的子弹序列,每位队员被告知这一序列的信息;同时,每位队员也被告知恐怖分子即将出现的序列和类型(同样用小写英文字母标明类型)。
3、在跑动的过程中,若发现“恐怖分子”,特警队员可以选择用枪击毙他,来得到写在“恐怖分子”胸前的得分,但是前提是他使用的子弹类型必须和“恐怖分子”类型相同,否则,即使击毙了“恐怖分子”,也得不到分数;当然选择不击毙他也是可以的,这样他不会从那个“恐怖分子”身上得到分数。
4、允许特警队员放空枪,这样可以消耗掉型号不对的子弹而不至于杀死“恐怖分子”(当然每个特警队员都不会愚蠢到不装消音装置就放空枪,以至于吓跑“恐怖分子”),等待枪口出现正确型号的子弹击毙他得分。

这里,我们假定:
1、对于每个队员,途中出现恐怖分子的地点、时间、类型也是完全一样的。
2、每颗子弹都是质量合格的,都可以发挥杀伤效力
3、由于队员各个都是神枪手,一旦他选择了正确的子弹,向目标射击,目标100%被爆头
4、每个队员的记忆力超强,能记住所有子弹序列信息和恐怖分子序列信息。
5、每个队员体力足够好,能跑完全程,并做他想要做的
6、“恐怖分子”是不动的,小范围内不存在多于一个的恐怖分子;

炜炜需要你的帮助,告诉他如何做,才能得到最高的分数。现在如果告诉你出发时枪膛内子弹的序号和型号、恐怖分子出现的序号和类型,你能告诉炜炜他最多能得到多少分数吗?
 

 

Input
输入数据的第一行有一个整数N表示子弹和恐怖分子的类型数。随后的一行是各种恐怖分子类型的一行字母,两个字母之间没有任何字符。接下来的一行是击毙上一行对应位置恐怖分子类型的得分数,每个分数之间恰有一个空格。第三第四行分别表示开始时枪膛内子弹的序列(左边的先打出)和恐怖分子出现的序列(左边的先出现),字母之间都没有任何字符。
每个测试数据之间没有空格和空行。你的程序必须通过全部测试数据,才能被判为AC。
 

 

Output
对于每一个测试数据,输出炜炜最多能得到的分数。
 

 

Sample Input
3
abc
1 1 1
abc
ccc
3
abc
1 1 1
ccc
aba
 

 

Sample Output
1
0
 
  中文题意不解释,这题跟两个字符串的最长公共子串有点像,但是最长公共子串a[i]==b[j]的时候,dp[i][j]=dp[i-1][j-1]+w,w是1,但是这里w是a[i]的价值。
  状态转移方程:
          dp[i][j]=dp[i-1][j-1]+w[a[i]]         a[i]==b[j];
               max{dp[i-1][j],dp[i][j-1]}   a[i]!=b[j];
  做的时候WA了一次,原因是数组开小了,因为题目没有说明字符串的长度有多长,所以只开了1000,后来改成10000就过了···
  因为字符串的长度有10000,所以这里需要用滚动数组。
 
上代码:
 
bubuko.com,布布扣
 1 #include <cstdio>
 2 #include <cstring>
 3 #define max(x,y) (x > y ? x : y)
 4 #define MAX 10002
 5 using namespace std;
 6 
 7 char a[MAX];
 8 char b[MAX];
 9 int s[MAX];
10 int n;
11 int dp[10][MAX];
12 
13 
14 
15 int main()
16 {
17     int l1,l2,maxn;
18     //freopen("data.txt","r",stdin);
19     while(scanf("%d",&n)!=EOF){
20         getchar();
21         scanf("%s",a);
22         l1=strlen(a);
23         memset(s,0,sizeof(s));
24         for(int i=0;i<l1;i++){
25             scanf("%d",&s[a[i]-a]);
26         }
27         getchar();
28         scanf("%s",a+1);
29         scanf("%s",b+1);
30         l1=strlen(a+1);
31         l2=strlen(b+1);
32         memset(dp,0,sizeof(dp));
33         maxn=0;
34         for(int i=1;i<=l1;i++){
35             for(int j=1;j<=l2;j++){
36                 if(a[i]==b[j]){
37                     dp[i%10][j]=dp[(i-1+10)%10][j-1]+s[a[i]-a];
38                 }else{
39                     dp[i%10][j]=max(dp[(i-1+10)%10][j],dp[i%10][j-1]);
40                 }
41                 maxn=max(dp[i%10][j],maxn);
42             }
43         }
44         printf("%d\n",maxn);
45     }
46     return 0;
47 }
1243

 

            

HDU - 1243 - 反恐训练营,布布扣,bubuko.com

HDU - 1243 - 反恐训练营

原文:http://www.cnblogs.com/sineatos/p/3572656.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!