链接:

http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1009&cid=872

题意:

在 dota2 中有一个叫做祈求者(Invoker)的英雄,在游戏中他有三个基础技能:冰(Quas),雷(Wex),火(Exort),每施展一个技能就可以获得相应属性的一个法球(element)。

但是祈求者同时最多只能有三个法球,即如果他在有三个法球的状态下又使用了某个法球技能,那么他会获得该法球,并失去之前三个法球中最先获得的一个。

不难得出,祈求者身上的三个法球的无顺序组合有 10 种,每一种都对应着一个组合技能:

  1. 急速冷却(Cold Snap),无序组合 QQQ,用 Y 表示
  2. 幽灵漫步(Ghost Walk),无序组合 QQW,用 V 表示
  3. 寒冰之墙(Ice Wall),无序组合 QQE,用 G 表示
  4. 电磁脉冲(EMP),无序组合 WWW,用 C 表示
  5. 强袭飓风(Tornado),无序组合 QWW,用 X 表示
  6. 灵动迅捷(Alacrity),无序组合 WWE,用 Z 表示
  7. 阳炎冲击(Sun Strike),无序组合 EEE,用 T 表示
  8. 熔炉精灵(Forge Spirit),无序组合 QEE,用 F 表示
  9. 混沌陨石(Chaos Meteor),无序组合 WEE,用 D 表示
  10. 超震声波(Deafening Blast),无序组合 QWE,用 B 表示

当祈求者拥有三个法球的时候,使用元素祈唤(Invoke)技能,用 R 表示,便可获得当前法球组合所对应的技能,同时原有的三个法球也不会消失,先后顺序的状态也不会改变。

现在给定一个技能序列,你想按照给定的顺序将他们一个一个地祈唤出来,同时你想用最少的按键来达到目标,所以你想知道对于给定的一个技能序列,最少按多少次键才能把他们都祈唤出来。

注意:游戏开始的时候,祈求者是没有任何法球的。

思路:

先打表每种情况, DP搞一下
每个点有6重情况, 暴力处理, 多组数据.....

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int MAXN = 1e5+10;
char Opt[15][6][5] = {{"QQQ", "QQQ", "QQQ", "QQQ", "QQQ", "QQQ"},{"QQW", "QWQ", "QQW", "QWQ", "WQQ", "WQQ"},{"QQE", "QEQ", "QQE", "QEQ", "EQQ", "EQQ"},{"WWW", "WWW", "WWW", "WWW", "WWW", "WWW"},{"QWW", "QWW", "WQW", "WWQ", "WQW", "WWQ"},{"WWE", "WEW", "WWE", "WEW", "EWW", "EWW"},{"EEE", "EEE", "EEE", "EEE", "EEE", "EEE"},{"QEE", "QEE", "EQE", "EEQ", "EQE", "EEQ"},{"WEE", "WEE", "EWE", "EEW", "EWE", "EEW"},{"QWE", "QEW", "WQE", "WEQ", "EQW", "EWQ"}};
map<char, int> Mp;
char s[MAXN];
int Dp[MAXN][6];bool Check(char *l, char *r)
{int len = strlen(l);for (int i = 0;i < len;i++){if (l[i] != r[i])return false;}return true;
}int Count(char *l, char *r)
{if (Check(l, r))return 0;if (Check(l+1, r))return 1;if (Check(l+2, r))return 2;return 3;
}void Init()
{Mp['Y'] = 0;Mp['V'] = 1;Mp['G'] = 2;Mp['C'] = 3;Mp['X'] = 4;Mp['Z'] = 5;Mp['T'] = 6;Mp['F'] = 7;Mp['D'] = 8;Mp['B'] = 9;
}int main()
{Init();scanf("%s", s);int len = strlen(s);memset(Dp, 0x3f3f3f, sizeof(Dp));for (int i = 0; i < 6; i++)Dp[0][i] = 3;for (int i = 1; i < len; i++){for (int j = 0; j < 6; j++){for (int k = 0; k < 6; k++){int cnt = Count(Opt[Mp[s[i - 1]]][k], Opt[Mp[s[i]]][j]);
//                cout << Opt[Mp[s[i-1]]][k] << ' ' << Opt[Mp[s[i]]][j] << ' ' << cnt << endl;Dp[i][j] = min(Dp[i][j], Dp[i - 1][k] + cnt);}}}int ans = Dp[len - 1][0];for (int i = 0; i < 6; i++)ans = min(ans, Dp[len - 1][i]);
//        for (int i = 0; i < len; i++)
//        {
//            for (int j = 0; j < 6; j++)
//                cout << Dp[i][j] << ' ';
//            cout << endl;
//        }printf("%d\n", ans + len);return 0;
}

转载于:https://www.cnblogs.com/YDDDD/p/11604872.html

2019CCPC秦皇岛赛区(重现赛)- I相关推荐

  1. HDU - 6739 2019CCPC秦皇岛赛区 I. Invoker(DP+思维)

    问题链接: http://acm.hdu.edu.cn/showproblem.php?pid=6739 问题简述: 在 dota2 中有一个叫做祈求者(Invoker)的英雄,在游戏中他有三个基础技 ...

  2. 2019ccpc秦皇岛赛区K. MUV LUV UNLIMITED(博弈)

    题目连接 题意:两个人在一棵树上玩游戏,两人轮流在树上选择一个以上的叶子进行删除.最后删掉根节点的人获胜,问是先手必胜还是后手必胜 (1).若只有一条链,则直接判奇偶(废话) (2).若不只一条链,则 ...

  3. 2019CCPC秦皇岛赛区 hdu 6740 MUV LUV EXTRA(KMP next数组)

    传送门 MUV LUV EXTRA Time Limit: 2000/1500 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Othe ...

  4. 2019CCPC江西省赛(重现赛)| 题目 题解

    2019CCPC江西省赛(重现赛)在hdu进行 据说很简单 因为现场有多个队伍AK 然鹅 我在40分钟内AC两题之后 就卡在概率题 (后来就没做题目emmm) 先放官方题解 然后慢慢补题 嗯! 题目: ...

  5. MUV LUV EXTRA 2019CCPC秦皇岛站J

    MUV LUV EXTRA 2019CCPC秦皇岛站J (hdu重现赛) 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6740 思路 kmp求循环节 ...

  6. 第十五届全国大学生智能汽车竞赛山东赛区国赛获奖队伍详细信息

    第十五届全国大学生智能汽车竞赛 山东赛区国赛获奖队伍详细信息 序号 学校 队伍 组别 奖项 姓名 类别 1 山东大学(威海) Lekima Storm 基础四轮组 一等奖 崔凌 参赛学生 2 山东大学 ...

  7. 2018 ACM 国际大学生程序设计竞赛上海大都会赛重现赛 F Color it

    链接:https://www.nowcoder.com/acm/contest/163/F 来源:牛客网 2018 ACM 国际大学生程序设计竞赛上海大都会赛重现赛 F Color it 时间限制:C ...

  8. 2017广西邀请赛重现赛

    总题解:http://www.nike0good.com/674.html 1001: 2017ACM/ICPC广西邀请赛-重现赛 1001 A Math Problem #include <i ...

  9. 全球地区资料json 含中英文 经纬度_2020年Brain Bee北京、天津、河北赛区地区赛参赛说明...

    本赛事信息转自微信公众号"ICP留学字典" 就在刚刚,Brain Bee官网正式公布了2020年Brain Bee脑科学大赛的参赛说明,新的赛季正式开始,报名已启动. 在今年,IC ...

最新文章

  1. idea 生成sdk,如何安装独立的Android SDK,然后将其添加到Windows上的IntelliJ IDEA?
  2. Titanium Developer
  3. pandas纵向合并数据
  4. 极高效代码(C语言):1008 数组元素循环右移问题 (20分)
  5. HashMap vs ConcurrentHashMap — 示例及Iterator探秘
  6. 利用Eigen进行矩阵计算
  7. 获取并编译linux源码,linux – 从源代码编译软件:如何收集依赖项列表?
  8. C++ 现代编程风格速查表
  9. 查看现有运行的linux服务器有多少内存条
  10. .net通用权限框架B/S (五)--WEB(1)首页
  11. 做短视频自媒体,常用工具和素材网站分享,新手小白收藏抓紧行动
  12. Xshell 3.0序列号注册激活教程
  13. css3 3d 太阳系,CSS3实现的太阳系行星系统
  14. struct tm 中的 tm_isdst 以及 mktime
  15. 推特Twitter API获取关注者名单
  16. 掌握命令结构,详解monkey命令
  17. jetpack4.5.1使用tensorrt加速模型
  18. 奔跑的业绩,需要配上奔跑的Excel条形图
  19. 2019牛客暑期多校训练营(第七场)-B Irreducible Polynomial(多项式因式分解)
  20. 编写 SQL 查询表格,按创建时间降序排列。

热门文章

  1. SpringMVC:通配符的匹配很全面, 但无法找到元素 ‘context:component-scan‘ 的声明
  2. laravel组件单独加载(2):模型 Eloquent ORM
  3. 如何下载吉林省卫星图高清版大图
  4. 不动点迭代法(C语言)
  5. Android开发之自定义随机验证码控件
  6. 【深搜】小孩分油问题
  7. 架构师之路系列:接口幂等性是个什么东东?如何实现接口幂等设计?
  8. 以太坊源码分析(10)CMD深入分析
  9. Logger Log4j2 could not find a logging implementation.解决方法
  10. workFlow学习总结-----------workFlow简介