bzoj1066 蜥蜴 (dinic)
最大流板子题。
对于每根柱子,建两个点ai,bi,建边(ai,bi,柱子高度)
对于距离不超过d的两根柱子i,j,建边(bi,aj,inf)
对于起始位置在i的每个蜥蜴,建边(S,ai,1)
对于能跳出地图的柱子i,建边(bi,E,inf)
然后跑dinic即可
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
const int maxn=,inf=0x3f3f3f3f; struct Edge{
int a,b,v;
int ne;
}eg[maxn*maxn*maxn*maxn*]; int R,C,D,pcnt,rcnt,ecnt;
int map[maxn][maxn][];
int rd[][];
int egh[maxn*maxn*],P[maxn][maxn][];
int deep[maxn*maxn*]; inline void addedge(int a,int b,int v){
eg[ecnt].a=a;eg[ecnt].b=b;eg[ecnt].v=v;eg[ecnt].ne=egh[a];egh[a]=ecnt++;
eg[ecnt].a=b;eg[ecnt].b=a;eg[ecnt].v=;eg[ecnt].ne=egh[b];egh[b]=ecnt++;
} bool bfs(){
queue<int> q;memset(deep,,sizeof(deep));
q.push();deep[]=;
while(!q.empty()){
int p=q.front();q.pop();
for(int i=egh[p];i!=-;i=eg[i].ne){
if(eg[i].v&&!deep[eg[i].b]){
q.push(eg[i].b);deep[eg[i].b]=deep[p]+;
}
}
}return deep[];
} int dinic(int x,int l){
if(x==) return l;int tmp=l;
for(int i=egh[x];i!=-;i=eg[i].ne){
if(deep[eg[i].b]!=deep[x]+||!eg[i].v) continue;
int re=dinic(eg[i].b,min(eg[i].v,l));
if(!re) deep[eg[i].b]=;
tmp-=re;eg[i].v-=re;eg[i^].v+=re;
if(!tmp) break;
}return l-tmp;
} int main(){
int i,j,k,ans=;
char s[maxn];
//freopen("1066.in","r",stdin);
scanf("%d%d%d",&R,&C,&D);
for(i=;i<=R;i++){
scanf("%s",s+);
for(j=;j<=C;j++) map[i][j][]=s[j]-'';
}
for(i=;i<=R;i++){
scanf("%s",s+);
for(j=;j<=C;j++) map[i][j][]=(s[j]=='L'?:);
}
for(i=-D;i<=D;i++){
for(j=-D;j<=D;j++){
if(i*i+j*j<=D*D){rd[rcnt][]=i;rd[rcnt++][]=j;}
}
}
pcnt=;memset(egh,-,sizeof(egh));
for(i=;i<=R;i++) for(j=;j<=C;j++) if(map[i][j][]){
P[i][j][]=++pcnt;P[i][j][]=++pcnt;addedge(P[i][j][],P[i][j][],map[i][j][]);
if(map[i][j][]) {addedge(,P[i][j][],);ans++;}
}
for(i=;i<=R;i++){
for(j=;j<=C;j++){
if(!map[i][j][]) continue;
bool b=;
for(k=;k<rcnt;k++){
int ii=i+rd[k][],jj=j+rd[k][];
if(ii<=||ii>R||jj<=||jj>C) b=;
else if(map[ii][jj]) addedge(P[i][j][],P[ii][jj][],inf);
}if(b) addedge(P[i][j][],,inf);
}
}
while(bfs()) ans-=dinic(,inf);
printf("%d",ans);
}
bzoj1066 蜥蜴 (dinic)的更多相关文章
- 蜥蜴-DInic
题目背景 07四川省选 题目描述 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离为1,蜥蜴的跳跃距离是d,即蜥蜴 ...
- BZOJ-1066 蜥蜴 最大流+拆点+超级源超级汇
1066: [SCOI2007]蜥蜴 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 2582 Solved: 1272 [Submit][Status] ...
- bzoj1066 蜥蜴
Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离为1,蜥蜴的跳跃距离是d,即蜥蜴可以跳到平 ...
- 【蒟蒻の进阶PLAN】 置顶+持续连载
看到周围神犇们纷纷列计划,本蒟蒻也决定跟随他们的步伐,计划大约是周计划吧,具体怎么安排我也不确定.. 2015.12.30 刚刚学习完最基础的网络流,需要进行这方面的练习,从简到难,有空余的话尝试学习 ...
- 【bzoj1066】[SCOI2007]蜥蜴 网络最大流
[bzoj1066][SCOI2007]蜥蜴 Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的 ...
- BZOJ1066 SCOI2007 蜥蜴 【网络流-最大流】
BZOJ1066 SCOI2007 蜥蜴 Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离 ...
- 【bzoj1066】: [SCOI2007]蜥蜴 图论-最大流
[bzoj1066]: [SCOI2007]蜥蜴 把石柱拆点,流量为高度 然后S与蜥蜴连流量1的边 互相能跳到的石柱连inf的边 石柱能到边界外的和T连inf的边 然后跑dinic就好了 /* htt ...
- [BZOJ1066][luogu_P2472][SCOI2007]蜥蜴
[BZOJ1066][luogu_P2472][SCOI2007]蜥蜴 试题描述 在一个 \(r\) 行 \(c\) 列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥 ...
- BZOJ1066 [SCOI2007]蜥蜴
首先...这是道(很水的)网络流 我们发现"每个时刻不能有两个蜥蜴在同一个柱子上"这个条件是没有用的因为可以让外面的先跳,再让里面的往外跳 但是还有柱子高度的限制,于是把柱子拆点为 ...
随机推荐
- Linux系统mysql使用(一)
一.安装 sudo apt-get update #更新软件源 sudo apt-get install mysql-server #安装mysql 二.启动和关闭 service mysql sta ...
- zabbix使用jmx监控tomcat
zabbix监控Tomcat/JVM实例性能(115) – 运维生存时间http://www.ttlsa.com/zabbix/zabbix-use-jmx-monitor-tomcat/ zabbi ...
- pip ipython启动错误 Fatal error in launcher: Unable to create process using
完整的错误提示: C:\Users\yyy>ipython3Fatal error in launcher: Unable to create process using '"c:\u ...
- 6-2 Verbs and Adjectives with that clauses
1 Many sentences in English contain two clauses: a main clause and a "that" clause. The &q ...
- [转帖]学习关于TTL
自己简单试了一下在家里与在公司里面服务器的连接: C:\Users\Administrator>tracert oms.inspur.com 通过最多 个跃点跟踪 到 oms.inspur.co ...
- 剑指offer(4)
题目: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2 ...
- Django--ORM 多表查询
一 . 建立外键 一对一建立外键 外键名称 = models.OneToOneField(to='要连接的类名', to_field='字段') 一对多建立外键 外键名称 = models.Forei ...
- Flask从入门到精通
1. flask的下载和安装 在windows下安装flask flask依赖于两个库, 即werkzeug 和jinja2 , werkzeug负责服务器的部署, jinja2负责模板引擎,管理安装 ...
- linux下更改MySQL数据库存储路径
参考地址:1.https://blog.csdn.net/ArnoBM/article/details/83008212 2.http://www.cnblogs.com/lyongde/p/3725 ...
- Python——Flask框架——程序的基本结构
一.安装 pip install flask 二.初始化 from flask import Flask app = Flash(__name__) 三.路由:处理URL和函数之间的关系的程序称为路由 ...