“知乎杯”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一个点 ...
随机推荐
- SSM前后端分离 ssm+html+js(ajax) 这种controll层的返回值是结合或者网址
提示: 1.单表查询多条数据用 list<实体类名字> mapper层 1.1单表查询单条数据用 对象 2.两表关联查多条 list<map<String,Object> ...
- C#录制声卡声音喇叭声音音箱声音
在项目中,我们会需要录制电脑播放的声音,比如歌曲,电影声音,聊天声音等通过声卡音箱发出的声音.那么如何采集呢?当然是采用SharpCapture!下面开始演示关键代码,您也可以在文末下载全部源码: 设 ...
- linux入门—安装linux系统(1)
一,linux介绍 linux是一套免费使用和自由传播的类Unix操作系统,简单的说就是不要钱,你可以随便使用,也可以分享给其他人. (剩下的详细内容,个人认为百度百科的内容比我瞎讲强的多,网址:ht ...
- nodeJS从入门到进阶一(基础部分)
一.Node.js基础知识 1.概念 简单的说 Node.js 就是运行在服务端的 JavaScript. Node.js 是JavaScript的运行环境 Node.js 使用了一个事件驱动.非阻塞 ...
- windows xp远程连接
本节将用到windows网络共享,实现外网可以远程连接局域网内的任意主机 实验环境 两台windows xp虚拟机(内网+外网),一台主机 配置外网虚拟机 首先,为虚拟机添加两块网卡.一块作为网关(内 ...
- POSIX 使用互斥量和条件变量实现生产者/消费者问题
boost的mutex,condition_variable非常好用.但是在Linux上,boost实际上做的是对pthread_mutex_t 和pthread_cond_t的一系列的封装.因此通过 ...
- idea忽略并隐藏.idea文件夹.iml文件不提交到svn
File-->setting-->Editor-->File Types 选中.boringignore,添加*.iml;.idea;即可
- 使用Hybris commerce的promotion rule进行促销活动
backoffice Marketing菜单下面,新建一个Promotion rule: Promotion的条件,设置成针对商城里所有的数码相机: Promotion触发条件在Conditions区 ...
- windows搭建测试环境
1.安装python 安装地址: https://www.python.org/downloads/windows/ Download Windows x86-64 executable insta ...
- jar - 操作jar包的工具
jar - Manipulates Java Archive (JAR) files. jar命令是一种通用的存档和压缩工具,基于ZIP和ZLIB压缩格式. 常用格式: * 创建jar文件 jar c ...