“知乎杯”2018 CCF 大学生计算机系统与程序设计竞赛 绝地求生(battleground)
/* Style Definitions */
table.MsoNormalTable
{mso-style-name:普通表格;
mso-tstyle-rowband-size:0;
mso-tstyle-colband-size:0;
mso-style-noshow:yes;
mso-style-priority:99;
mso-style-parent:"";
mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
mso-para-margin:0cm;
mso-para-margin-bottom:.0001pt;
mso-pagination:widow-orphan;
font-size:10.5pt;
mso-bidi-font-size:11.0pt;
font-family:等线;
mso-ascii-font-family:等线;
mso-ascii-theme-font:minor-latin;
mso-fareast-font-family:等线;
mso-fareast-theme-font:minor-fareast;
mso-hansi-font-family:等线;
mso-hansi-theme-font:minor-latin;
mso-font-kerning:1.0pt;}
CSPfinal 2018
绝地求生
• 对于第1个子任务,由于所有玩家都在安全区内,直接输出玩家初始生命值即可;
• 对于第2个和第4个子任务,由于数据量较小,可以从玩家开始向安全区做路径搜索;
• 对于第3个和第5个子任务,由于数据量较大,可以从安全区做一次路径搜索;
• 每回合开始清除安全区内的障碍物,每回合结束恢复安全区内的障碍物;
• 玩家不能进入障碍物的方格;
if(abstacles[xnew][ynew]==1) return;
• 也不能穿越两个斜向相邻障碍物方格的间隙;
if(abstacles[xold][ynew]&&abstacles[xnew][yold]==1) return;
把所有安全区的点放入队列,bfs,得到初始点到安全区的最短距离。
题目保证每个玩家给出的目标坐标一定在安全区域以内。保证在任意回合,对于任意玩家,都存在一条到达本回合目标位置的移动路线
所以本次的最短距离即为本轮该玩家的扣血量。
if(!vis[np.x][np.y]&&dat(np)&&(!(i&1)||dat(cp+dir[i-1])||dat(cp+dir[i+1])))
简明而清晰的判断下一个点是否可达,下一个点是否出界
#include<queue>
#include<cstdio>
#include<cstring>
const int N=+;
const int M=1e5+;
int n,m,ne,f,h,r,hp[M],dis[N][N];
bool data[N][N],vis[N][N];
template <typename T>
inline void read(T &x){
T f=;char ch=getchar();x=;
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
x*=f;
}
struct Point{
int x,y;
Point(int _x=,int _y=):x(_x),y(_y){}
inline void Read(){
read(x);read(y);x++;y++;
}
inline int sqr(){
return x*x+y*y;
}
inline Point operator +(const Point &a) const{
return Point(x+a.x,y+a.y);
}
inline Point operator -(const Point &a) const{
return Point(x-a.x,y-a.y);
}
}pos[M],cent;
const Point dir[]={
Point(, ), Point(, ), Point(, ), Point(, -),
Point(, -), Point(-, -), Point(-, ), Point(-, ),
Point(, )
};
inline void Init(){
read(n);read(m);read(ne);read(f);read(h);
for(int i=;i<=n;i++) for(int j=;j<=n;j++) data[i][j]=;
for(int i=;i<=ne;i++){
Point p;p.Read();
data[p.x][p.y]=;
}
for(int i=;i<=m;i++) pos[i].Read();
for(int i=;i<=m;i++) hp[i]=h;
}
inline bool dat(const Point& a){
return data[a.x][a.y];
}
inline void bfs(){
std::queue<Point>q;
memset(vis,,sizeof vis);
for(int i=std::max(,cent.x-r),rx=std::min(n,cent.x+r);i<=rx;i++){
for(int j=std::max(,cent.y-r),ry=std::min(n,cent.y+r);j<=ry;j++){
if((Point(i,j)-cent).sqr()<=r*r){
q.push(Point(i,j));
vis[i][j]=;
dis[i][j]=;
}
}
}
while(!q.empty()){
Point cp=q.front();q.pop();
for(int i=;i<;i++){
Point np=cp+dir[i];
if(!vis[np.x][np.y]&&dat(np)&&(!(i&)||dat(cp+dir[i-])||dat(cp+dir[i+]))){
vis[np.x][np.y]=;
dis[np.x][np.y]=dis[cp.x][cp.y]+;
q.push(np);
}
}
}
for(int i=;i<=m;i++) hp[i]-=dis[pos[i].x][pos[i].y],pos[i].Read();
}
inline void Solve(){
while(f--){
cent.Read();read(r);
bfs();
}
for(int i=;i<=m;i++) printf("%d\n",hp[i]<?:hp[i]);
}
int main(){
freopen("battleground.in","r",stdin);
freopen("battleground.out","w",stdout);
Init();
Solve();
fclose(stdin);fclose(stdout);
return ;
}
“知乎杯”2018 CCF 大学生计算机系统与程序设计竞赛 绝地求生(battleground)的更多相关文章
- “知乎杯”2018 CCF 大学生计算机系统与程序设计竞赛 分组加密器(encryption)
分组加密器(encryption) 题解点这里 #include<map> #include<stack> #include<vector> #include< ...
- “知乎杯”2018 CCF 大学生计算机系统与程序设计竞赛 贪心算法(greedy)
--> 贪心算法 1)题解 • 分别用V0.V1和V>=2表示度为0.1以及至少为2的顶点集合 • 对于每个顶点,维护三个属性: • degree ...
- 中国大学生计算机系统与程序设计竞赛 CCF-CCSP-2016 选座( ticket_chooser )
选座( ticket_chooser ) 不会正解,欢迎讨论 //60分 #include<cstdio> #define max(a,b) (a)>(b)?a:b #define ...
- 中国大学生计算机系统与程序设计竞赛 CCF-CCSP-2017 串行调度(serial)
串行调度(serial) 除等价条件, 根据题意设置限制条件,然后求字典序最小拓扑序. 简洁版 #include<bits/stdc++.h> using namespace std; ; ...
- "字节跳动杯"2018中国大学生程序设计竞赛-女生专场 Solution
A - 口算训练 题意:询问 $[L, R]$区间内 的所有数的乘积是否是D的倍数 思路:考虑分解质因数 显然,一个数$x > \sqrt{x} 的质因子只有一个$ 那么我们考虑将小于$\sqr ...
- "字节跳动杯"2018中国大学生程序设计竞赛-女生专场
口算训练 #include <iostream> #include <algorithm> #include <cstring> #include <cstd ...
- “纽劢科技杯”第十六届同济大学程序设计竞赛暨上海邀请赛同步赛 J-张老师的游戏
传送门 题目描述 在空闲时间,张老师习惯性地和菜哭武玩起了取石子游戏,这次的游戏规则有些不同,在他们面前有n堆石子,其中,第i堆石子的个数为a[i],现在制定规则如下: 从张老师开始, ...
- CTF 湖湘杯 2018 WriteUp (部分)
湖湘杯 2018 WriteUp (部分),欢迎转载,转载请注明出处! 1. CodeCheck(WEB) 测试admin ‘ or ‘1’=’1’# ,php报错.点击登录框下面的滚动通知,URL ...
- 2018 ACM 国际大学生程序设计竞赛上海大都会部分题解
题目链接 2018 ACM 国际大学生程序设计竞赛上海大都会 下午午休起床被同学叫去打比赛233 然后已经过了2.5h了 先挑过得多的做了 .... A题 rand x*n 次点,每次judge一个点 ...
随机推荐
- Unity - 绘制正五边形网格
本文简述了Unity中绘制正五边形网格的基本方法:计算顶点信息.设置三角形覆盖信息.创建配置mesh 绘制方法 基本思路:计算出五边形顶点坐标信息作为数组,设置三角形包围方式,再创建新的mesh配置v ...
- yii框架中的下拉菜单和单选框
yii中的下拉菜单: 第一种: <?= $form->field($model, 'parent_id')->dropDownList(ArrayHelper::map($data, ...
- JAVA8的java.util.function包
一 概述 name type description Consumer Consumer< T > 接收T对象,不返回值 Predicate Predicate< T > 接收 ...
- JMeter学习笔记(十八)——返回的响应数据出现中文乱码_解决方案
一.问题描述 使用jmeter过程中遇到了请求返回的响应数据出现中文乱码 二.原因分析 当没有对响应数据or响应页面设置支持解析中文的编码时,JMeter则会以默认的ISO-8859-1格式解析,而其 ...
- 魅族手机使用应用沙盒一键修改imsi数据
较早前文章介绍了怎么在安卓手机上安装激活XPosed框架,XPosed框架的牛逼之处功能各位都介绍过,可以不修改apk的前提下,修改系统内核的参数,打比方在某些应用领域,各位需要修改手机的某个系统参数 ...
- 结对项目(java实现)
一 .Github项目地址:https://github.com/734635746/MyApp 二.PSP表格 PSP2.1 Personal Software Process Stages 预估耗 ...
- Java集合框架 面试问题整理
简介 java集合类是java.util 包中的重要内容.java集合框架包含了大量集合接口以及这些接口的实现类和操作他们的算法. java集合框架图 主要提供的数据结构 List 又称有序的Coll ...
- Shell 行遍历命令行的输出结果
对于命令行输出的结果,如果要遍历,一般都是用for循环遍历,具体语法为: for line in `ls` do dosomethingdone 此时对于ls这类语句的输出结果,在遍历的时候会 ...
- HTML&CSS基础-超链接
HTML&CSS基础-超链接 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.如下图所示,有三个网页 <!DOCTYPE html> <!--Docty ...
- Linux的rwx