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]蜥蜴
首先...这是道(很水的)网络流 我们发现"每个时刻不能有两个蜥蜴在同一个柱子上"这个条件是没有用的因为可以让外面的先跳,再让里面的往外跳 但是还有柱子高度的限制,于是把柱子拆点为 ...
随机推荐
- 【kindle笔记】之 《明朝那些事儿》-2018-7-1
[kindle笔记]读书记录-总 最近在读这本书.之前在微信读书里断断续续读过,读到深处还想蹦起来做笔记那种.后来种种原因断了,再没续上. 现在又开始啦.最近还在重八兄造反阶段,还很早呢,有时候晚上玩 ...
- 11-vue的使用
一.安装 对于新手来说,强烈建议大家使用<script>引入 二. 引入vue.js文件 我们能发现,引入vue.js文件之后,Vue被注册为一个全局的变量,它是一个构造函数. 三.使用V ...
- asp.net core Api配置swagger
这个很简单的一篇文章用来记录以下使用swagger的过程,以后有用. 1.nuget 下载install-package Swashbuckle.AspNetCore 2.startup里面confi ...
- css特殊样式
span{ color: blue; border:1px solid black;}.extra span{ color: inherit;} 清除原有样式 text-decoration: non ...
- 高并发之API接口限流
在开发高并发系统时有三把利器用来保护系统:缓存.降级和限流 缓存 缓存的目的是提升系统访问速度和增大系统处理容量 降级 降级是当服务出现问题或者影响到核心流程时,需要暂时屏蔽掉,待高峰或者问题解决后再 ...
- Delphi (Library Path Browsing Path)
首先要明白的一个概念是dcu文件 *.dcu是*.pas的编译后单元文件(Delphi Compiled Unit), 编译器把它和库文件连接起来就构成了可执行文件*.exe 或*.dll等,相当于C ...
- File类 详解!
package cn.zhoucufeng; import java.io.File; import java.io.IOException; import java.util.Arrays; imp ...
- java 中 System
package cn.zhou.com; /* * System 类 * * 不能实列化 * * long t=System.currentTimeMillis();//用于计算程序的执行时间! * ...
- vue-resource: jsonp请求百度搜索的接口
1. yarn add vue-resource 2. main.js引入vue-resource import Vue from 'vue' import MintUI from 'mint-ui' ...
- 安装zip版mysql
MySQL安装文件分为两种,一种是msi格式的,一种是zip格式的.如果是msi格式的可以直接点击安装,按照它给出的安装提示进行安装(相信大家的英文可以看懂英文提示),一般MySQL将会安装在C:\P ...