luogu P1526 [NOI2003]智破连环阵 搜索+最大匹配+剪枝
LINK:智破连环阵
考试的时候 题意没理解清楚 题目是指一个炸弹爆炸时间结束后再放另一个炸弹 而放完一个炸弹紧接另一个炸弹。题目中存在然后二字.
这样我们可以发现某个炸弹只会炸连续的一段。
但是 由于点的坐标虽然只在第一象限 炸弹也在第一象限 不过简单的设出几个状态可以发现 是不可行的。
状压也不行。考虑贪心但是还是要要考虑坐标以及序号的问题 所以很难贪出正确答案。
无奈之下只能选择搜索了 一种比较简单的搜索方式还是搜出把序列分段。
可以发现这样复杂度最坏是2^n的。
求出分段之后我们还需要考虑匹配问题。
容易发现是一个二分图的问题直接跑匈牙利即可。
考虑加剪枝以优化。
一个比较容易想到的剪枝:最优化剪枝 对于当前点x 我们可以预估一个最优答案d[x]表示x~n都可以被满足且此时炸弹随便选的最小炸弹数 这样这个最优化剪枝的效果更好且保证答案正确。
一个可行性剪枝:搜出当前分段后 先判断一下最大匹配是否成功再继续搜下去。
一个接替前驱答案的优化:不需要每次最大匹配重新跑 可以直接直接拿上一层的结果跑。
注意枚举区间由大到小做 这样也可以加快。
一些其他剪枝我没加:如精确判断区间的右断点的最大延伸。这个还需要判断一下交错路什么的我觉得比较复杂 复杂度也比较高 所以就没加。在数据随机的情况下上述剪枝已经很快了。
const int MAXN=110;
int ans,n,m,k,id;//炸弹m个 n个点 a[i][j]表示第i个炸弹是否可以炸到点j.
int a[MAXN][MAXN],c[MAXN][MAXN],d[MAXN];//c[i][j]表示第i个炸弹从j点开始炸的最远点.
struct wy{int x,y;}A[MAXN],B[MAXN];//d[i]表示i~n个点被炸在每个点被用多次时的最小值.
inline int pd(int x,int y){return pf(B[x].x-A[y].x)+pf(B[x].y-A[y].y)<=pf(k);}
int f[MAXN],w[MAXN][MAXN],vis[MAXN];
inline void prepare()
{
rep(1,m,i)fep(n,1,j)if(a[i][j])c[i][j]=max(j,c[i][j+1]);
fep(n,1,i){d[i]=INF;rep(1,m,j)if(a[j][i])d[i]=min(d[i],d[c[j][i]+1]+1);}
}
inline int dfs(int x)
{
rep(1,m,i)
{
if(vis[i]!=id&&w[i][x])
{
vis[i]=id;
if(!f[i]||dfs(f[i]))
{
f[i]=x;
return 1;
}
}
}
return 0;
}
inline void dfs(int x,int v)
{
if(v+d[x]>=ans)return;
if(x==n+1){ans=v;return;}
int g[MAXN];
rep(1,m,i)g[i]=f[i];
fep(n,x,i)
{
rep(1,m,j)if(c[j][x]>=i)w[j][v+1]=1;
++id;if(dfs(v+1))dfs(i+1,v+1);
rep(1,m,j)if(c[j][x]>=i)w[j][v+1]=0;
rep(1,m,j)f[j]=g[j];
}
}
int main()
{
freopen("1.in","r",stdin);
get(n);get(m);get(k);
rep(1,n,i){int get(x);A[i]=(wy){x,read()};}
rep(1,m,i){int get(x);B[i]=(wy){x,read()};}
rep(1,m,i)rep(1,n,j)a[i][j]=pd(i,j);
prepare();ans=INF;dfs(1,0);put(ans);
return 0;
}
luogu P1526 [NOI2003]智破连环阵 搜索+最大匹配+剪枝的更多相关文章
- P1526 [NOI2003]智破连环阵
目录 题意描述 算法分析 闲话 初步分析 具体思路 剪枝一 剪枝二 剪枝三 总结一下 代码实现 预处理 剪枝一 剪枝二 剪枝三 二分图匹配 代码综合 结语 又是被楼教主虐的体无完肤的一天 题意描述 在 ...
- 题解-NOI2003 智破连环阵
题面 NOI2003 智破连环阵 有 \(m\) 个靶子 \((ax_j,ay_j)\) 和 \(n\) 个箭塔 \((bx_i,by_i)\).每个箭塔可以射中距离在 \(k\) 以内的靶子.第 \ ...
- bzoj4622 [NOI 2003] 智破连环阵
Description B国在耗资百亿元之后终于研究出了新式武器——连环阵(Zenith Protected Linked Hybrid Zone).传说中,连环阵是一种永不停滞的自发性智能武器.但经 ...
- 【21.00%】【vijos P1018】智破连环阵
描述 B国在耗资百亿元之后终于研究出了新式武器--连环阵(Zenith Protected Linked Hybrid Zone).传说中,连环阵是一种永不停滞的自发性智能武器.但经过A国间谍的侦察发 ...
- [luogu1526]智破连环阵
(以下在描述复杂度时,认为$n$和$m$相同,因此一律使用$n$) 称第$i$个炸弹能匹配非空区间$[l,r]$,当且仅当$l$到$r$内所有武器都在$i$攻击范围内,且$r=m$或第$r+1$个武器 ...
- bzoj 4622: [NOI 2003] 智破连环阵【dfs+匈牙利算法】
一个炸弹炸一个区间的武器,想到二分图匹配 但是直接dfs断点显然不行,预处理出dis[i]为i到m的至多值来最优性剪枝,并且标记ok[i][j]为炸弹i可以炸到j武器,mx[i][j]为i炸弹从j武器 ...
- 搜索(剪枝优化):HDU 5113 Black And White
Description In mathematics, the four color theorem, or the four color map theorem, states that, give ...
- Luogu 2756 飞行员配对方案问题(二分图最大匹配)
Luogu 2756 飞行员配对方案问题(二分图最大匹配) Description 英国皇家空军从沦陷国征募了大量外籍飞行员.由皇家空军派出的每一架飞机都需要配备在航行技能和语言上能互相配合的2 名飞 ...
- [CF293B]Distinct Paths_搜索_剪枝
Distinct Paths 题目链接:http://codeforces.com/problemset/problem/293/B 数据范围:略. 题解: 带搜索的剪枝.... 想不到吧..... ...
随机推荐
- Navicat远程连接MySQL 提示1045 - Access denied for user 'root'@'223.74.158.192'(using password:YES)
问题: 今天在自己的阿里云服务器上(Window Server2012 R2)安装了一个MySQL5.7.26,在阿里云服务器中通过本地链接是正常的,但是当在自己的电脑上使用Navicat连接是提示: ...
- python入门005
垃圾回收机制详解(了解) 1.引用计数 x = 10 # 直接引用 print(id(x)) y = x z = x l = ['a', 'b', x] # 间接引用 print(id(l[2])) ...
- Kafka入门(1):概述
摘要 在本文中,我将从为什么需要消息队列开始讲起,举两个小例子,跟你聊聊目前消息队列的一些使用场景. 比如消息队列在复杂系统中的解耦,又比如消息队列在高并发下的场景如果让流量变得更平缓. 随后我会跟你 ...
- Mybatis插件扩展以及与Spring整合原理
@ 目录 前言 正文 插件扩展 1. Interceptor核心实现原理 2. Mybatis的拦截增强 Mybatis与Spring整合原理 1. SqlSessionFactory的创建 2. 扫 ...
- JavaScript location对象、Navigator对象、Screen对象简介
Location对象 location用于获取或设置窗体的URL,并且可以用于解析URL. 语法: location.[属性|方法] Location对象属性 Location对象方法: Naviga ...
- requests接口自动化3-url里带参数的get请求:params
url里带参数的get请求:用params传参 #2.带参数的get请求,把参数写成字典格式,用params传参 para2={"type":"math"} r ...
- python 爬虫写入txt:UnicodeEncodeError: ‘gbk’ codec can’t encode character 错误的解决办法
原链接:https://blog.csdn.net/vito21/article/details/53490435 今天爬一个网站的内容,在写入TXT文件时,某些页面总是报UnicodeEncodeE ...
- javascript基础(三): 操作DOM对象(重点)
DOM:文档对象模型 核心 浏览器网页就是一个Dom树形结构! 更新:更新Dom节点 遍历Dom节点:得到Dom节点 删除:删除一个Dom节点 添加:添加一个新的节点 要操作一个Dom节点,就必须要先 ...
- 使用MapReduce运行WordCount案例
@ 目录 一.准备数据 二.MR的编程规范 三.编程步骤 四.编写程序 Mapper程序解读 一.准备数据 注意:准备的数据的格式必须是文本,每个单词之间使用制表符分割.编码必须是utf-8无bom ...
- 为Dark模拟做出的一些微小的贡献
这几周经过liners大佬的指导,发现自己的代码实现能力确实太过于垃圾,所以根据他的指示,我应该去多多练习一下Dark模拟,但是最近刚刚入手Dark模拟的我感到非常的吃力,所以本人今天写博客一篇来讲述 ...