2019-2020 ICPC Southwestern European Regional Programming Contest (SWERC 2019-20) L题(SG+状压)
题意:给定一个N*N的表格,其上有三种类型的方格:坚实的地面、潮湿的区域和保护区。连通的湿区方格形成湿区,当两个正方形共用一条边时,它们被认为是连接的。每个湿区必须连接到网格的左右两侧,并且不包含超过2N的湿区方块。属于两个不同湿区的两个湿区方格之间的距离始终至少为3,距离=abs(x-dx)+abs(y-dy)。你和你的朋友将轮流在湿地旁放置一个摄像头,但有以下限制:1. 摄像机必须放在坚固的地面上。2. 相机必须靠近湿区广场,这样你才能拍到鸟的照片。3. 摄像机不得位于保护区广场上。4. 同一个方格上不能有两个摄像头。5. 同一湿区相邻的两个摄像机不能相邻(相邻的概念意味着共享一个边)。 第一个不能放置相机的玩家将输掉游戏。假设两个玩家都玩得很好,第一个玩家会赢还是输?
输入格式:第一行一个整数N(N <= 10),接下来是一个N*N的字符矩阵,“*”代表湿区方格,‘.’代表坚实的地面,‘x’代表保护区。
输出格式:第一个玩家升输出“First player will win”,否则输出“Second player will win”
分析:思路状压+SG。定义可以放摄像头的地面为可行方格,相邻的可行方格组成的连通块称为可行区。将每个湿区编号,注意到不同湿区方格间曼哈顿距离不小于3,故每个可行方格只与一个湿区相邻,所以一个可行区的摄像头放置情况不会影响其他可行区,所以每个可行区间可看作独立的Nim游戏,用状压分别求出SG值异或起来即可。因为湿区方格不超过2*N,所以可行区的方格数不会超过2*N,复杂度正确。
#include<cstdio>
#include<vector>
#include<cstring>
#define pb(a) push_back(a)
const int maxn = 1e4; //st数组代表该潮湿的方格所属湿区编号,org数组表示该可行方格相邻的湿区编号
int N,tot,cnt,kk,SG;
int sg[2000005],org[12][12],st[12][12],to[4][2] = {{0, 1}, {0, -1}, {-1, 0}, {1, 0}};
char ss[12][12];
bool vis[12][12];
std::vector<int> x[100], y[100]; inline int abs(int a) { return a < 0 ? -a : a; } // 找湿地连通块,对不同连通块进行编号
void dfs(int x, int y){
for(int i = 0; i < 4; ++i){
int dx = x + to[i][0], dy = y + to[i][1];
if(ss[dx][dy] == '*' && !vis[dx][dy]) vis[dx][dy] = 1, st[dx][dy] = st[x][y], dfs(dx, dy);
else if(ss[dx][dy] == '.') org[dx][dy] = st[x][y]; // 确定可行方格所属湿区编号
}
} //存下可行区中各方格坐标
void dfs_(int xx, int yy, int k){
//printf("%d %d\n", xx, yy);
for(int i = 0; i < 4; ++i){
int dx = xx + to[i][0], dy = yy + to[i][1];
if(org[dx][dy] == org[xx][yy] && !vis[dx][dy]){
vis[dx][dy] = 1;
x[k].pb(dx), y[k].pb(dy); //该方格属于第k个可行区
dfs_(dx, dy, k);
}
}
} //now表示当前状压的状态,id表示可行区编号,num表示可行区内方格数
void get_sg(int now, int id, int num){
if(sg[now]) return ;
bool ok, is[maxn];
memset(is, 0, sizeof(is));
for(int i = 0; i < num; ++i){
if((now & (1 << i)) == 0){
ok = 1;
for(int t = 0; t < num; ++t){
if(t == i) continue;
if(abs(x[id][t] - x[id][i]) + abs(y[id][t] - y[id][i]) == 1 && (now & (1 << t))) { ok = 0; break; }
}
if(ok){
get_sg(now | (1 << i), id, num);
is[sg[now | (1 << i)]] = 1;
}
}
}
for(int i = 0; i < maxn; ++i)
if(!is[i]){
sg[now] = i;
return ;
}
} int main(){
scanf("%d", &N);
for(int i = 1; i <= N; ++i) scanf("%s", ss[i]+1);
for(int i = 1; i <= N; ++i)
for(int t = 1; t <= N; ++t)
if(ss[i][t] == '*' && !vis[i][t]){
vis[i][t] = 1, st[i][t] = ++tot, dfs(i, t);
}
for(int i = 1; i <= N; ++i)
for(int t = 1; t <= N; ++t)
if(ss[i][t] == '.' && !vis[i][t] && org[i][t]){
vis[i][t] = 1;
x[++kk].pb(i), y[kk].pb(t);
dfs_(i, t, kk);
}
for(int i = 1; i <= kk; ++i){
memset(sg, 0, sizeof(sg));
get_sg(0, i, x[i].size());
SG ^= sg[0];
}
if(SG) puts("First player will win");
else puts("Second player will win");
return 0;
}
2019-2020 ICPC Southwestern European Regional Programming Contest (SWERC 2019-20) L题(SG+状压)的更多相关文章
- Gym 2009-2010 ACM ICPC Southwestern European Regional Programming Contest (SWERC 2009) A. Trick or Treat (三分)
题意:在二维坐标轴上给你一堆点,在x轴上找一个点,使得该点到其他点的最大距离最小. 题解:随便找几个点画个图,不难发现,答案具有凹凸性,有极小值,所以我们直接三分来找即可. 代码: int n; lo ...
- 2016-2017 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2016) F dfs序+树状数组
Performance ReviewEmployee performance reviews are a necessary evil in any company. In a performance ...
- 2016-2017 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2016)
A. Within Arm's Reach 留坑. B. Bribing Eve 枚举经过$1$号点的所有直线,统计直线右侧的点数,旋转卡壳即可. 时间复杂度$O(n\log n)$. #includ ...
- 2017-2018 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2017)
A. Cakey McCakeFace 按题意模拟即可. #include<stdio.h> #include<iostream> #include<string.h&g ...
- 2016-2017 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2016) B - Bribing Eve
地址:http://codeforces.com/gym/101174/attachments 题目:pdf,略 思路: 把每个人的(x1,x2)抽象成点(xi,yi). 当1号比i号排名高时有==& ...
- 2016-2017 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2016) D.Dinner Bet 概率DP+排列组合
题目链接:点这里 题意: 1~N标号的球 现在A有C个,B有C个 每次可以随机得到D个不同的球(1~N);问你A或B中的C个球都出现一次的 期望次数 题解: dp[i][j][k]表示 随机出现了i个 ...
- 2016-2017 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2016) E.Passwords AC自动机+dp
题目链接:点这里 题意: 让你构造一个长度范围在[A,B]之间 字符串(大小写字母,数字),问你有多少种方案 需要满足条件一下: 1:构成串中至少包含一个数字,一个大写字母,一个小写字母: 2:不 ...
- 2017-2018 ACM-ICPC Southeastern European Regional Programming Contest (SEERC 2017)
2017-2018 ACM-ICPC Southeastern European Regional Programming Contest (SEERC 2017) 全靠 wxh的博客 补完这套.wx ...
- 2018-2019 ACM-ICPC Southeastern European Regional Programming Contest (SEERC 2018)
layout: post title: 2018-2019 ACM-ICPC Southeastern European Regional Programming Contest (SEERC 201 ...
- 2018-2019 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2018)-E. Explosion Exploit-概率+状压dp
2018-2019 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2018)-E. Explosion Exploit-概率+状压dp [P ...
随机推荐
- [selenium]浏览器基本操作
前言 版本: python:3.9 selenium:4.1.5 浏览器:firefox 创建浏览器对象 from selenium import webdriver driver = webdriv ...
- Linux:通过命令查找日志文件中的某字段
工作中有用到,做个记录. 1. 查询某字段,显示行号: cat -n file_name|grep '查找字段' [root@ZWZF-CWY-LZY-12 CWY]# cat -n nohup.ou ...
- 如何使用Grid中的repeat函数
在本文中,我们将探索 CSS Grid repeat() 函数的所有可能性,它允许我们高效地创建 Grid 列和行的模式,甚至无需媒体查询就可以创建响应式布局. 不要重复自己 通过 grid-temp ...
- 商品详情接口设计:使用API调用获取淘宝商品数据的完整方案
在如今的电商时代,获取商品的详细信息是实现商业化应用的基础.本文将详细介绍如何通过API调用来获取淘宝商品数据,并提供一个完整的商品详情接口设计方案,包括代码示例.开发人员可以根据此方案快速实现商 ...
- 淘宝详情api接口的应用
淘宝详情API接口是一个基于HTTP协议的接口服务,可用于获取淘宝商品的具体信息.下面将介绍如何调用淘宝详情API接口获取淘宝商品数据的步骤. 1.注册账号并创建应用 首先,我们需要进行账号注册.实名 ...
- 算术逻辑单元的实现(ALU)
一.实验目的 掌握Vivado集成开发环境 掌握Verilog语言基本知识. 掌握并理解算术逻辑单元ALU的原理和设计 二.实验预习 1.ALU(算术逻辑单元)的16种运算的编码 三.模块接口设计 A ...
- DeferredResult异步处理spring mvc Demo
一.概述 spring mvc同步接口在请求处理过程中一直处于阻塞状态,而异步接口可以启用后台线程去处理耗时任务.简单来说适用场景: 1.高并发: 2.高IO耗时操作. 二.Demo Spring M ...
- 如何实现一个数据库的 UDF?图数据库 NebulaGraph UDF 功能背后的设计与思考
大家好,我是来自 BOSS直聘的赵俊南,主要负责安全方面的图存储相关工作.作为一个从 v1.x 用到 v3.x 版本的忠实用户,在见证 NebulaGraph 发展的同时,也和它一起成长. BOSS直 ...
- MySQL 表分区使用实践
在使用 MySQL 8.0 表分区时,需要注意以下一些关键事项和最佳实践: 支持的存储引擎: MySQL 8.0 表分区仅支持一些特定的存储引擎,如 InnoDB 和 NDB(NDB 是 MySQL ...
- 逻辑漏洞挖掘之XSS漏洞原理分析及实战演练
一.前言 2月份的1.2亿条用户地址信息泄露再次给各大公司敲响了警钟,数据安全的重要性愈加凸显,这也更加坚定了我们推行安全测试常态化的决心.随着测试组安全测试常态化的推进,有更多的同事对逻辑漏洞产生了 ...