J - Mr.Panda and TubeMaster
时间:2019-06-13
本文章向大家介绍J - Mr.Panda and TubeMaster,主要包括J - Mr.Panda and TubeMaster使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
题解
我们可以把每个格子拆成两个点,一个表示横向的,一个表示纵向的,相邻的格子横向和纵向连边。
如果直接按照题意做的话,我们应当在横向和纵向的点之间连边,有限制的边设下界为1,然后跑可行流。
或者考虑用链覆盖的思想,我们把横向点当成入点,纵向点当成出点,然后相邻的入点连向出点。
入点和出点之间连边表示的是如果流这条边,那么这个格子不放,那么有限制的格子就不连这条边。
源点连入点,出点连汇点,最大费用最大流。
代码
#include<bits/stdc++.h>
#define N 2009
#define M 33
#define inf 1e9
using namespace std;
typedef long long ll;
const int xi=-2e8;
queue<int>q;
int head[N],tot,he[M][M],zo[M][M],l[M][M],r[M][M],n,m,num;
int dis[N],fl[N],ans,pre[N],flow;
bool ex[M][M];
bool vis[N];
inline ll rd(){
ll x=0;char c=getchar();bool f=0;
while(!isdigit(c)){if(c=='-')f=1;c=getchar();}
while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return f?-x:x;
}
struct edge{
int n,to,l,f;
}e[N*10];
inline void add(int u,int v,int l,int f){
e[++tot].n=head[u];e[tot].to=v;head[u]=tot;e[tot].l=l;e[tot].f=f;
e[++tot].n=head[v];e[tot].to=u;head[v]=tot;e[tot].l=0;e[tot].f=-f;
}
inline bool spfa(int s,int t){
memset(dis,-0x3f,sizeof(dis));
q.push(s);dis[s]=0;fl[s]=2e9;
while(!q.empty()){
int u=q.front();q.pop();vis[u]=0;
// cout<<u<<" "<<dis[u]<<endl;
for(int i=head[u];i;i=e[i].n){
int v=e[i].to;
if(e[i].l&&dis[v]<dis[u]+e[i].f){
dis[v]=dis[u]+e[i].f;pre[v]=i;fl[v]=min(fl[u],e[i].l);
if(!vis[v]){vis[v]=1;q.push(v);}
}
}
}
return dis[t]>xi;
}
inline void calc(int s,int t){
int x=t;
while(x!=s){
int i=pre[x];
e[i].l-=fl[t];e[i^1].l+=fl[t];x=e[i^1].to;
}
ans+=dis[t]*fl[t];
flow+=fl[t];
}
inline void solve(){
tot=1;num=0;
n=rd();m=rd();
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)l[i][j]=++num,r[i][j]=++num;
for(int i=1;i<=n;++i)
for(int j=1;j<m;++j)he[i][j]=rd();
for(int i=1;i<n;++i)
for(int j=1;j<=m;++j)zo[i][j]=rd();
for(int i=1;i<=n;++i){
for(int j=1;j<=m;++j){
if((i+j)&1){
if(j<m)add(l[i][j],r[i][j+1],1,he[i][j]);
if(j>1)add(l[i][j],r[i][j-1],1,he[i][j-1]);
}
else{
if(i>1)add(l[i][j],r[i-1][j],1,zo[i-1][j]);
if(i<n)add(l[i][j],r[i+1][j],1,zo[i][j]);
}
}
}
int mm=rd();
for(int i=1;i<=mm;++i){
int x=rd(),y=rd();
ex[x][y]=1;
}
int S=0,T=num+1;
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j){
add(S,l[i][j],1,0);
add(r[i][j],T,1,0);
if(!ex[i][j])add(l[i][j],r[i][j],1,0);
}
while(spfa(S,T))calc(S,T);
if(flow!=n*m)puts("Impossible");
else cout<<ans<<endl;
}
inline void unit(){
memset(ex,0,sizeof(ex));
memset(head,0,sizeof(head));
ans=0;flow=0;
}
int main(){
int T=rd(),tt=0;
while(T--){
++tt;
printf("Case #%d: ",tt);
solve();
unit();
}
return 0;
}
原文地址:https://www.cnblogs.com/ZH-comld/p/11013976.html
- hdu----(2222)Keywords Search(ac自动机)
- MySQL数据库(四):约束条件
- hdu----(2084)数塔(dp)
- golang简单tls协议用法完整示例
- spark开发环境详细教程1:IntelliJ IDEA使用详细说明
- MySQL数据库(五):索引
- hdu----(1466)计算直线的交点数(dp)
- golang模板template自定义函数用法示例
- 程序员你为什么这么累【续】:编写简陋的接口调用框架 - 动态代理学习
- hdu---(Tell me the area)(几何/三角形面积以及圆面积的一些知识)
- MySQL数据库(六):体系结构和存储引擎
- hdu----(2222)Keywords Search(trie树)
- MySQL数据库(七):数据导出与导入
- flume与kafka整合高可靠教程
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 在群晖docker上构建私有云IDE和devops构建链
- 小白学PyTorch | 14 tensorboardX可视化教程
- Apache Solr 漏洞复现
- Elasticsearch rollover API
- 重发和重定向有什么区别与重定向应用
- 为tinycolinux制作应用包
- CrossC2的2.0版本
- 使用OpenCV和Python计算图像的“色彩”
- 为tinycolinux创建应用包-toolchain和编译方法
- [译]在Solidity中如何优化Gas第一部分:变量
- [译]Solidity 0.7.0 新变化
- 两个数组的交集 II
- 常说的手机刷新率60Hz、120Hz有什么不同?
- Istio 运维实战系列(3):让人头大的『无头服务』-下
- java安全编码指南之:可见性和原子性