第三月模拟题——炉石传说
炉石传说
问题描述
《炉石传说:魔兽英雄传》(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏(如下图所示)。游戏在一个战斗棋盘上进行,由两名玩家轮流进行操作,本题所使用的炉石传说游戏的简化规则如下:
- 玩家会控制一些角色,每个角色有自己的生命值和攻击力。当生命值小于等于 0 时,该角色死亡。角色分为英雄和随从。
- 玩家各控制一个英雄,游戏开始时,英雄的生命值为 30,攻击力为 0。当英雄死亡时,游戏结束,英雄未死亡的一方获胜。
- 玩家可在游戏过程中召唤随从。棋盘上每方都有 7 个可用于放置随从的空位,从左到右一字排开,被称为战场。当随从死亡时,它将被从战场上移除。
- 游戏开始后,两位玩家轮流进行操作,每个玩家的连续一组操作称为一个回合。
- 每个回合中,当前玩家可进行零个或者多个以下操作:
1) 召唤随从:玩家召唤一个随从进入战场,随从具有指定的生命值和攻击力。
2) 随从攻击:玩家控制自己的某个随从攻击对手的英雄或者某个随从。
3) 结束回合:玩家声明自己的当前回合结束,游戏将进入对手的回合。该操作一定是一个回合的最后一个操作。 - 当随从攻击时,攻击方和被攻击方会同时对彼此造成等同于自己攻击力的伤害。受到伤害的角色的生命值将会减少,数值等同于受到的伤害。例如,随从 X 的生命值为 HX、攻击力为 AX,随从 Y 的生命值为 HY、攻击力为 AY,如果随从 X 攻击随从 Y,则攻击发生后随从 X 的生命值变为 HX - AY,随从 Y 的生命值变为 HY - AX。攻击发生后,角色的生命值可以为负数。
本题将给出一个游戏的过程,要求编写程序模拟该游戏过程并输出最后的局面。
Input
输入第一行是一个整数 n,表示操作的个数。接下来 n 行,每行描述一个操作,格式如下:
…
其中表示操作类型,是一个字符串,共有 3 种:summon表示召唤随从,attack表示随从攻击,end表示结束回合。这 3 种操作的具体格式如下:
* summon :当前玩家在位置召唤一个生命值为、攻击力为的随从。其中是一个 1 到 7 的整数,表示召唤的随从出现在战场上的位置,原来该位置及右边的随从都将顺次向右移动一位。
* attack :当前玩家的角色攻击对方的角色 。是 1 到 7 的整数,表示发起攻击的本方随从编号,是 0 到 7 的整数,表示被攻击的对方角色,0 表示攻击对方英雄,1 到 7 表示攻击对方随从的编号。
* end:当前玩家结束本回合。
注意:随从的编号会随着游戏的进程发生变化,当召唤一个随从时,玩家指定召唤该随从放入战场的位置,此时,原来该位置及右边的所有随从编号都会增加 1。而当一个随从死亡时,它右边的所有随从编号都会减少 1。任意时刻,战场上的随从总是从1开始连续编号。
Output
输出共 5 行。
第 1 行包含一个整数,表示这 n 次操作后(以下称为 T 时刻)游戏的胜负结果,1 表示先手玩家获胜,-1 表示后手玩家获胜,0 表示游戏尚未结束,还没有人获胜。
第 2 行包含一个整数,表示 T 时刻先手玩家的英雄的生命值。
第 3 行包含若干个整数,第一个整数 p 表示 T 时刻先手玩家在战场上存活的随从个数,之后 p 个整数,分别表示这些随从在 T 时刻的生命值(按照从左往右的顺序)。
第 4 行和第 5 行与第 2 行和第 3 行类似,只是将玩家从先手玩家换为后手玩家。
Example
- input
8
summon 1 3 6
summon 2 4 2
end
summon 1 4 5
summon 1 2 1
attack 1 2
end
attack 1 1
- output
0
30
1 2
30
1 2
样例说明
按照样例输入从第 2 行开始逐行的解释如下:
1. 先手玩家在位置 1 召唤一个生命值为 6、攻击力为 3 的随从 A,是本方战场上唯一的随从。
2. 先手玩家在位置 2 召唤一个生命值为 2、攻击力为 4 的随从 B,出现在随从 A 的右边。
3. 先手玩家回合结束。
4. 后手玩家在位置 1 召唤一个生命值为 5、攻击力为 4 的随从 C,是本方战场上唯一的随从。
5. 后手玩家在位置 1 召唤一个生命值为 1、攻击力为 2 的随从 D,出现在随从 C 的左边。
6. 随从 D 攻击随从 B,双方均死亡。
7. 后手玩家回合结束。
8. 随从 A 攻击随从 C,双方的生命值都降低至 2。
评测用例规模与约定
* 操作的个数0 ≤ n ≤ 1000。
* 随从的初始生命值为 1 到 100 的整数,攻击力为 0 到 100 的整数。
* 保证所有操作均合法,包括但不限于:
1) 召唤随从的位置一定是合法的,即如果当前本方战场上有 m 个随从,则召唤随从的位置一定在 1 到 m + 1 之间,其中 1 表示战场最左边的位置,m + 1 表示战场最右边的位置。
2) 当本方战场有 7 个随从时,不会再召唤新的随从。
3) 发起攻击和被攻击的角色一定存在,发起攻击的角色攻击力大于 0。
4) 一方英雄如果死亡,就不再会有后续操作。
* 数据约定:
前 20% 的评测用例召唤随从的位置都是战场的最右边。
前 40% 的评测用例没有 attack 操作。
前 60% 的评测用例不会出现随从死亡的情况。
解题思路
本题解题思路较为简单。
对于英雄与随从的各个属性使用结构体封装即可。
然后要注意的地方就是在执行操作的过程中注意玩家先手后手的转换,当一方英雄血量<=0时,不需要删除元素,输出的血量可能为负数
代码实现
#include <iostream>
#include <stdio.h>
#include <vector>
#include <string>
#include <string.h>
using namespace std;int n, now_plr, now_idx, next_idx, next_plr,ack, hlh;
string s;struct Hero{int health, attack;Hero(int h, int att){ health = h, attack = att; }void ini(int h, int att){ health = h, attack = att; }Hero operator-(const Hero &a) { health -= a.attack; return *this; }Hero operator-=(const Hero &a) { return (*this - a); }
};Hero t(30, 0);
vector<Hero> heros[2];void output()
{if(heros[0][0].health<=0)cout << "-1" << endl;else if(heros[1][0].health<=0)cout << "1" << endl;elsecout << "0" << endl;cout << heros[0][0].health << endl<< heros[0].size() - 1 << " ";for(int i=1;i<heros[0].size();i++)cout<<heros[0][i].health<<" ";cout << endl<< heros[1][0].health << endl<<heros[1].size()-1<<" ";for(int i=1;i<heros[1].size();i++)cout<<heros[1][i].health<<" ";cout << endl;
}int main()
{cin >> n;heros[0].push_back(t);heros[1].push_back(t);for(int i=0;i<n;i++){cin>>s;if(s=="summon"){cin>>now_idx>>ack>>hlh;t.ini(hlh, ack);vector<Hero>::iterator iter = heros[now_plr].begin();heros[now_plr].insert(iter+now_idx, t);}if(s=="attack"){cin>>now_idx>>next_idx;next_plr = 1 - now_plr;heros[now_plr][now_idx] -= heros[next_plr][next_idx];heros[next_plr][next_idx] -= heros[now_plr][now_idx];vector<Hero>::iterator iter1 = heros[now_plr].begin(), iter2 = heros[next_plr].begin();if(heros[now_plr][now_idx].health<=0&&now_idx!=0)heros[now_plr].erase(iter1+now_idx);if(heros[next_plr][next_idx].health<=0&&next_idx!=0)heros[next_plr].erase(iter2+next_idx);}if(s=="end")now_plr = 1 - now_plr;}output();return 0;
}
第三月模拟题——炉石传说相关推荐
- 三月模拟题——炉石传说
炉石传说(CSP 201609-3) 一.题目 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏( ...
- csp模拟题-炉石传说
题目 试题编号: 201609-3 试题名称: 炉石传说 时间限制: 1.0s 内存限制: 256.0MB 问题描述: <炉石传说:魔兽英雄传>(Hearthstone: Heroes o ...
- 程序设计思维月模拟题2-CSP201609-3 炉石传说
以我开卡包的水平这游戏只能叫炉石稀有 问题描述 本题所使用的炉石传说游戏的简化规则如下: * 玩家会控制一些角色,每个角色有自己的生命值和攻击力.当生命值小于等于 0 时,该角色死亡.角色分为英雄和随 ...
- SDU月模拟题CSP201609-3炉石传说
问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏(如下图所示). 游戏在一个战斗棋盘上进 ...
- 月模拟题3 201609-3 炉石传说
炉石传说 题意 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏(如下图所示).游戏在一个战斗棋盘 ...
- 炉石传说 酒馆战棋 战斗模拟的实现
炉石传说 酒馆战棋 战斗模拟的实现 这几天工作闲余,琢磨着新的AI算法思路,于是想尝试一下和机器对战,遂想到炉石传说的酒馆战棋.想要机器对战,就得先把规则写成一个sandbox,然后再机器学习.那么这 ...
- 【CSP201609-3】炉石传说【模拟】
题意: 规则: 玩家会控制一些角色,每个角色有自己的生命值和攻击力.当生命值小于等于 0 时,该角色死亡.角色分为英雄和随从. 玩家各控制一个英雄,游戏开始时,英雄的生命值为 30,攻击力为 0.当英 ...
- 模拟【CSP201609-3炉石传说】
炉石传说 题意: <炉石传说:魔兽英雄传>(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏(如下图所示).游戏在一个战斗棋 ...
- CCF 201609-3 炉石传说 解题报告 模拟
题目: 问题描述 试题编号: 201612-3 试题名称: 炉石传说 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 <炉石传说:魔兽英雄传>(Hearthston ...
最新文章
- 使用 C#/.NET Core 实现单体设计模式
- 读入excel中的数据到数据库中
- Qt窗口屏幕居中显示 (ZT)
- python -归并排序
- shell 整数条件判断
- Mybatis源码阅读(三):结果集映射3.3 —— 主键生成策略
- 所有 HTTP 状态代码及其定义
- python科学计算库
- cad2019菜单栏怎么调出来_cad怎样调出菜单栏(cad2016工具栏怎么调出来)
- Windows 在Windows中关闭/最小化窗口的几种快捷方法
- Python 缩写月份单词
- IT痴汉的工作现状23-乡关何处
- thinkadmin 单页面多个富文本初始化
- html贝塞尔曲线在线,【HTML+js+纯前端】三次方贝塞尔曲线手工拟合小工具
- opencv读取透明图片
- AHB总线笔记(一)
- SQL语句——基础篇
- 模拟电子技术 半导体基本知识 个人笔记
- 物流快递电子面单HTML接口API代码-快递100
- armbian清理_小孩子才做选择,OMV、HomeAssistant我全都要,小白也能看懂的N1盒子纯净刷机指南...
热门文章
- 服务器中的固态硬盘优缺点,「服务器」固态硬盘的优缺点有哪些
- 北京移动长漫亲情省业务(长途、漫游超便宜)
- 海康摄像机RTSP连接Opencv读取视频
- 微信公众号服务号申请-模板消息发送-自定义菜单-测试账号指南
- java资源文件路径_Java 中获取资源(文件)的路径问题总结
- 201943 ovf 文件的导出和导入
- 1080P、2k、4k、帧、fps等概念区别
- 手机屏幕常见故障_手机屏幕失灵怎么回事 手机屏幕失灵解决办法
- 嵌入式开发需要学mysql吗_学习嵌入式开发需要学习哪些课程?如何学习?
- 【Cesium】【vue】空间查询——量距(测量距离)、量面(测量面积)