蜥蜴-DInic
题目背景
07四川省选
题目描述
在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外。
每行每列中相邻石柱的距离为1,蜥蜴的跳跃距离是d,即蜥蜴可以跳到平面距离不超过d的任何一个石柱上。石柱都不稳定,每次当蜥蜴跳跃时,所离开的石柱高度减1(如果仍然落在地图内部,则到达的石柱高度不变),如果该石柱原来高度为1,则蜥蜴离开后消失。以后其他蜥蜴不能落脚。任何时刻不能有两只蜥蜴在同一个石柱上。
输入输出格式
输入格式:
输入第一行为三个整数r,c,d,即地图的规模与最大跳跃距离。以下r行为石竹的初始状态,0表示没有石柱,1~3表示石柱的初始高度。以下r行为蜥蜴位置,“L”表示蜥蜴,“.”表示没有蜥蜴。
输出格式:
输出仅一行,包含一个整数,即无法逃离的蜥蜴总数的最小值。
输入输出样例
5 8 2
00000000
02000000
00321100
02000000
00000000
........
........
..LLLL..
........
........
1
说明
100%的数据满足:1<=r, c<=20, 1<=d<=3
写代码时犯了三个错误
*注意柱子间建边条件。满足条件:不在同一列 或 不在同一行 不是既 在同一列 或 不在同一行。
*读入的是字符。
*出图条件。
*数组大小。至多有400个点。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#include<vector>
#include<math.h>
using namespace std;
#define M 99893535
int c,r,d,dd,s,t,tot,na[][],ans,m1[][],dep[],map[][];
char m2[][];
int dfs(int u,int t,int f)
{
if(u==t) return f;
int d;
for(int v=;v<=tot;v++)
if(map[u][v]>&&dep[v]==dep[u]+&&(d=dfs(v,t,min(f,map[u][v]))))
{
map[u][v]-=d;
map[v][u]+=d;
return d;
}
return ;
}
int bfs(int s=,int t=)
{
queue<int>q;q.push(s);
memset(dep,-,sizeof(dep));
dep[s]=;
while(!q.empty()){
int u=q.front();q.pop();
for(int v=;v<=tot;v++)
if(map[u][v]>&&dep[v]==-)
{
dep[v]=dep[u]+;
q.push(v);
}
}
return dep[t]!=-;
}
int dinic()
{
int flow=,f=;
while(bfs(,))
while(){
f=dfs(,,M);
if(!f) break;
flow+=f;
}
return flow;
}
void find(int x,int y)
{
int now=na[x][y]+;
for(int i=;i<=r;i++)
for(int j=;j<=c;j++)
if( (i!=x||j!=y) &&m1[i][j]>)
if(d*d>= ((x-i)*(x-i)+(y-j)*(y-j)) )
map[now][ na[i][j] ]=M;
}
int main()
{
s=,t=,tot=;
scanf("%d%d%d",&r,&c,&d);
for(int i=;i<=r;i++)
for(int j=;j<=c;j++)
{
char oo;
cin>>oo;
m1[i][j]=oo-'';
if(m1[i][j])
{
int w=na[i][j]=++tot;tot++;
map[w][w+]=m1[i][j]; }
}
char o;
for(int i=;i<=r;i++)
for(int j=;j<=c;j++)
{
cin>>o; m2[i][j]=o;
if(o=='L')
{
int w=na[i][j];
map[s][w]=;
ans++;
}
}
for(int i=;i<=r;i++)
for(int j=;j<=c;j++)
if(m1[i][j])
{
find(i,j);
if(i<=d||j<=d||(r-i+)<=d||(c-j+)<=d)
map[ na[i][j]+ ][t]=M ;
}
printf("%d",ans-dinic());
return ;
}
蜥蜴-DInic的更多相关文章
- bzoj1066 蜥蜴 (dinic)
最大流板子题. 对于每根柱子,建两个点ai,bi,建边(ai,bi,柱子高度) 对于距离不超过d的两根柱子i,j,建边(bi,aj,inf) 对于起始位置在i的每个蜥蜴,建边(S,ai,1) 对于能跳 ...
- 1066: [SCOI2007]蜥蜴
1066: [SCOI2007]蜥蜴 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 3545 Solved: 1771[Submit][Status] ...
- bzoj 1066 蜥蜴
最大流. 建图:首先将每根柱子拆成两个点. 每根柱子的入点向出点连一条容量为柱子高度的边. 每根柱子的出点向可以到达的柱子的入点连一条容量为正无穷的边. 源点向每根初始有蜥蜴的柱子的入点连一条容量为一 ...
- BZOJ 1066 【SCOI2007】 蜥蜴
Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离为$1$,蜥蜴的跳跃距离是d,即蜥蜴可以跳 ...
- 蜥蜴(bzoj 1066)
Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离为1,蜥蜴的跳跃距离是d,即蜥蜴可以跳到平 ...
- BZOJ 1066 POJ 2711 [SCOI2007]蜥蜴
与POJ 1815 Friendship类似,该题之前也做过 目前处于TLE状态.样例已经通过 1066: [SCOI2007]蜥蜴 Time Limit: 1 Sec Memory Limit: ...
- 【bzoj1066】[SCOI2007]蜥蜴 网络最大流
[bzoj1066][SCOI2007]蜥蜴 Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的 ...
- BZOJ1066 [SCOI2007]蜥蜴
首先...这是道(很水的)网络流 我们发现"每个时刻不能有两个蜥蜴在同一个柱子上"这个条件是没有用的因为可以让外面的先跳,再让里面的往外跳 但是还有柱子高度的限制,于是把柱子拆点为 ...
- poj 2711 Leapin' Lizards && BZOJ 1066: [SCOI2007]蜥蜴 最大流
题目链接:http://poj.org/problem?id=2711 题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1066 Your p ...
随机推荐
- Derived 派生类
#include "stdafx.h"#include "iostream" using namespace std; class Base1{public: ...
- 用python做自动化测试--Python实现远程性能监控
http://blog.csdn.net/powerccna/article/details/8044222 在性能测试中,监控被测试服务器的性能指标是个重要的工作,包括CPU/Memory/IO/N ...
- opencv3.4.0 安装过程中出现的问题
重新安装opencv3.4.0 参考安装博客: opencv 安装版本测试:pkg-config --modversion opencv https://blog.csdn.net/cocoaqin/ ...
- 使用svnsync实时备份SVN版本库
前段时间把SVN版本库从win迁移到了Linux上,没隔几天那台win的磁盘就严重坏道了....这TMD什么运气! 花费了点时间研究了下svn自己的同步工具.写个日志记录下. 注意:svnsync要求 ...
- HDU 1143 Tri Tiling 递归问题
将一个3*n的矩形用1*2的矩形填充,n为奇数时一定不能被填满,n*3%2==1 接下来处理这个问题我们要从简单的情况开始考虑,所谓递归就是要能将问题的规模不断减小,通过小问题的解决最后将复杂问题解决 ...
- 微信小程序基础组件
所有的组件与属性都是小写,以连字符 - 连接 共同的属性类型: class id style bind*/catch* hidden data-* block标签. <block> 并不是 ...
- 简单易用"里程碑"、"时间轴"<iOS小组件>
非常感谢,帮助我的朋友们,谢谢你们.上次我的好朋友指出了我编码上(jwTextFiled工具组件)存在一些不规范问题,这次注意提高. 呆毛地址:https://github.com/NIUXINGJI ...
- Prime Independence
题意: 对于给定集合,求解最大的子集合,使得集合内两两之商不为质数. 解法: 考虑对于每一个数字分解质因数可以得到 $O(nloglogNUM)$ 条两个数字不可以出现在同一集合的信息. 同时发现一条 ...
- CF-807A
A. Is it rated? time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...
- A - Alyona and Numbers
Description After finishing eating her bun, Alyona came up with two integers n and m. She decided to ...