热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【USACO12JAN】视频游戏中连击技巧的分析与应用

在这款视频游戏中,Bessie需要操作三个按钮A、B和C来完成各种任务。通过对这些按钮的组合使用,玩家可以触发连击技巧,从而获得更高的分数。本文详细分析了这些连击技巧的实现方法及其在游戏中的应用,为玩家提供了有效的策略建议。

题目描述

Bessie is playing a video game! In the game, the three letters &#39;A&#39;, &#39;B&#39;, and &#39;C&#39; are the only valid buttons. Bessie may press the buttons in any order she likes; however, there are only N distinct combos possible (1 <= N <= 20). Combo i is represented as a string S_i which has a length between 1 and 15 and contains only the letters &#39;A&#39;, &#39;B&#39;, and &#39;C&#39;.

Whenever Bessie presses a combination of letters that matches with a combo, she gets one point for the combo. Combos may overlap with each other or even finish at the same time! For example if N = 3 and the three possible combos are "ABA", "CB", and "ABACB", and Bessie presses "ABACB", she will end with 3 points. Bessie may score points for a single combo more than once.

Bessie of course wants to earn points as quickly as possible. If she presses exactly K buttons (1 <= K <= 1,000), what is the maximum number of points she can earn?

贝西在玩一款游戏,该游戏只有三个技能键 “A”“B”“C”可用,但这些键可用形成N种(1 <= N<= 20)特定的组合技。第i个组合技用一个长度为1到15的字符串S_i表示。

当贝西输入的一个字符序列和一个组合技匹配的时候,他将获得1分。特殊的,他输入的一个字符序列有可能同时和若干个组合技匹配,比如N=3时,3种组合技分别为"ABA", "CB", 和"ABACB",若贝西输入"ABACB",他将获得3分。

若贝西输入恰好K (1 <= K <= 1,000)个字符,他最多能获得多少分?

输入输出格式

输入格式:
  • Line 1: Two space-separated integers: N and K.

  • Lines 2..N+1: Line i+1 contains only the string S_i, representing combo i.
输出格式:
  • Line 1: A single integer, the maximum number of points Bessie can obtain.

输入输出样例

输入样例#1:

3 7
ABA
CB
ABACB

输出样例#1:

4

说明

The optimal sequence of buttons in this case is ABACBCB, which gives 4 points--1 from ABA, 1 from ABACB, and 2 from CB.

 

题解:

记cnt[i]为节点i沿着fail一直走下去可以获得的积分,那么

f[i][j]为走了i步到节点j的最大积分 注意初始化...

f[i][a[j].next[k]]=max(f[i][a[j].next[k]],f[i-1][j]+a[a[j].next[k]].cnt);

1 #include
2 #include
3 #include
4 #include
5 #include
6 using namespace std;
7 const int INF=-2e8;
8 struct node
9 {
10 int next[3];
11 int cnt;
12 }a[505];
13 int f[1005][505];
14 int root=0,num=0,fail[505];
15 char s[1005];
16 void Clear()
17 {
18 a[num].cnt=0;
19 for(int i=0;i<3;i++)a[num].next[i]=0;
20 }
21 void add()
22 {
23 scanf("%s",s);
24 int p=root;
25 for(int i=0,ls=strlen(s);i)
26 {
27 if(a[p].next[s[i]-&#39;A&#39;])p=a[p].next[s[i]-&#39;A&#39;];
28 else
29 {
30 a[p].next[s[i]-&#39;A&#39;]=++num;
31 Clear();
32 p=num;
33 }
34 }
35 a[p].cnt++;
36 }
37 void getfail()
38 {
39 queue<int>q;
40 q.push(root);
41 int u,p,v;
42 while(!q.empty())
43 {
44 u=q.front();q.pop();
45 for(int i=0;i<3;i++)
46 {
47 if(!a[u].next[i])
48 {
49 if(a[fail[u]].next[i])a[u].next[i]=a[fail[u]].next[i];
50 continue;
51 }
52 p=fail[u];
53 while(p)
54 {
55 if(a[p].next[i])break;
56 p=fail[p];
57 }
58 if(a[p].next[i] && a[p].next[i]!=a[u].next[i])fail[a[u].next[i]]=a[p].next[i];
59 v=a[u].next[i];
60 a[v].cnt+=a[fail[v]].cnt;
61 q.push(a[u].next[i]);
62 }
63 }
64 }
65 int main()
66 {
67 //freopen("pp.in","r",stdin);
68 int n,k,ans=0;
69 scanf("%d%d",&n,&k);
70 for(int i=1;i<=n;i++)
71 add();
72 getfail();
73 for(int i=0;i<=k;i++)
74 for(int j=0;j<=num;j++)
75 f[i][j]=INF;
76 f[0][0]=0;
77 for(int i=1;i<=k;i++)
78 {
79 for(int j=0;j<=num;j++)
80 {
81 for(int k=0;k<3;k++)
82 {
83 f[i][a[j].next[k]]=max(f[i][a[j].next[k]],f[i-1][j]+a[a[j].next[k]].cnt);
84 }
85 }
86 }
87 for(int i=1;i<=num;i++)if(f[k][i]>ans)ans=f[k][i];
88 printf("%d\n",ans);
89 return 0;
90 }

 


转载于:https://www.cnblogs.com/Yuzao/p/7105592.html


推荐阅读
  • 深入解析 Android 中 EditText 的 getLayoutParams 方法及其代码应用实例 ... [详细]
  • ButterKnife 是一款用于 Android 开发的注解库,主要用于简化视图和事件绑定。本文详细介绍了 ButterKnife 的基础用法,包括如何通过注解实现字段和方法的绑定,以及在实际项目中的应用示例。此外,文章还提到了截至 2016 年 4 月 29 日,ButterKnife 的最新版本为 8.0.1,为开发者提供了最新的功能和性能优化。 ... [详细]
  • C#编程中按钮控件的使用与优化 ... [详细]
  • 本文介绍了UUID(通用唯一标识符)的概念及其在JavaScript中生成Java兼容UUID的代码实现与优化技巧。UUID是一个128位的唯一标识符,广泛应用于分布式系统中以确保唯一性。文章详细探讨了如何利用JavaScript生成符合Java标准的UUID,并提供了多种优化方法,以提高生成效率和兼容性。 ... [详细]
  • 本文深入探讨了 hCalendar 微格式在事件与时间、地点相关活动标记中的应用。作为微格式系列文章的第四篇,前文已分别介绍了 rel 属性用于定义链接关系、XFN 微格式增强链接的人际关系描述以及 hCard 微格式对个人和组织信息的描述。本次将重点解析 hCalendar 如何通过结构化数据标记,提高事件信息的可读性和互操作性。 ... [详细]
  • 本文详细介绍了 jQuery 的入门知识与实战应用,首先讲解了如何引入 jQuery 库及入口函数的使用方法,为初学者提供了清晰的操作指南。此外,还深入探讨了 jQuery 在实际项目中的多种应用场景,包括 DOM 操作、事件处理和 AJAX 请求等,帮助读者全面掌握 jQuery 的核心功能与技巧。 ... [详细]
  • 在iOS设备上实现闪光灯的开关控制功能,可以通过编写自定义的ViewController代码来实现。本文介绍了具体的实现方法,并提供了详细的代码示例,帮助开发者轻松掌握这一功能的开发技巧。 ... [详细]
  • 开发笔记:深入解析Android自定义控件——Button的72种变形技巧
    开发笔记:深入解析Android自定义控件——Button的72种变形技巧 ... [详细]
  • UGUI:借鉴NGUI的事件监听机制实现高效交互设计
    在Unity中,UGUI借鉴了NGUI的事件监听机制,以实现高效且便捷的交互设计。通过采用类似NGUI的UIEventListener方法,UGUI不仅简化了UI开发流程,还提升了项目的整体性能和用户体验。经过一段时间的实际应用,我们发现这种机制在复杂项目中表现尤为出色,能够显著提高开发效率和代码可维护性。 ... [详细]
  • 在CentOS 6.5环境中,本文详细介绍了如何配置SSH无密钥登录,并成功执行PSSH命令。首先,确保系统已安装PSSH工具,可使用 `yum install pssh` 进行安装。若未配置免密钥登录,PSSH命令将无法正常执行,例如尝试运行 `pssh -H root@192.168.245.129 -i uptime` 时会失败。通过生成并分发SSH公钥,可以实现无密码登录,从而顺利执行PSSH命令。此外,本文还提供了详细的步骤和常见问题的解决方案,帮助用户顺利完成配置。 ... [详细]
  • Eclipse JFace Text框架中IDocument接口的getNumberOfLines方法详解与编程实例 ... [详细]
  • 大家好,我是梅巴哥er。本文将深入探讨Redux框架中的第三个实战案例,具体实现每两秒自动点击按钮以触发颜色变化的功能。该案例中,一个关键点在于是否需要使用异步操作来处理定时任务,我们将详细分析其必要性和实现方式。通过这一实例,读者可以更好地理解Redux在实际项目中的应用及其异步处理机制。 ... [详细]
  • 英语面试技巧:提升个人技能与表现
    在英语面试中,个人技能是指除专业知识外,能够促进职业发展的各种能力。虽然你可能具备多种技能,但建议重点突出与目标岗位最相关的几项,以增强面试官对你专业能力和适应性的认可。 ... [详细]
  • 深入解析JWT的实现与应用
    本文深入探讨了JSON Web Token (JWT) 的实现机制及其应用场景。JWT 是一种基于 RFC 7519 标准的开放性认证协议,用于在各方之间安全地传输信息。文章详细分析了 JWT 的结构、生成和验证过程,并讨论了其在现代 Web 应用中的实际应用案例,为开发者提供了全面的理解和实践指导。 ... [详细]
  • 如何利用Git实现高效的多人协作开发(远程仓库应用实例)——Ares Zhao
    Git作为一种分布式版本控制系统,每位开发者都是本地仓库的管理者。然而,为了实现团队间的高效协作,需要将本地的开发成果推送至远程共享仓库,以便其他成员能够同步更新。本文将以GitHub为例,详细介绍如何通过设置和使用远程仓库,实现多人协作开发的最佳实践。 ... [详细]
author-avatar
花落---守护者
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有