#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#define P 55
#define N 2050
#define INF (1<<30) using namespace std; int n,m,S,T,ss,tt,cnt=,tot=;
int head[N],d[N],p[N],qlc[P],qrc[P],qlr[P],qrr[P];
int map[P][P],sc[P],sr[P],r[P],c[P],dis[N];
int ans,tl;
struct Edge{ int a,b,v,cost,next; }e[*N];
void add(int a,int b,int v,int cost) {
e[++cnt].a = a;
e[cnt].b = b;
e[cnt].v = v;
e[cnt].cost = cost;
e[cnt].next = head[a];
head[a] = cnt;
} inline void add_Node(int a,int b,int vl,int vr,int cost) {
//printf("Node %d %d %d %d\n",a,b,vl,vr);
d[a] -= vl; d[b] += vl;
add(a,b,vr-vl,cost); add(b,a,,-cost);
}
void paul() {
ss = tot+; tt = tot+;
for (int _=;_<=tot;_++) {
if (d[_] < ) add(_,tt,-d[_],) , add(tt,_,,);
if (d[_] > ) add(ss,_, d[_],) , add(_,ss,,);
}
} #define cp e[i].v
#define B e[i].b bool SPFA() {
bool flag = false;
memset(p,,sizeof(p));
memset(dis,0x3f3f3f3f,sizeof(dis));
dis[ss] = ;
queue<int> q; q.push(ss);
while (!q.empty()) {
int u = q.front(); q.pop();
if (u == tt) flag = true;
for (int i=head[u];i;i=e[i].next)
if (cp > && dis[u] + e[i].cost < dis[B]) {
dis[B] = dis[u] + e[i].cost;
p[B] = i;
q.push(B);
}
}
return flag;
} void mcf() {
int g = p[tt] , flow = INF;
while (g) {
flow = min(flow , e[g].v);
g = p[ e[g].a ];
}
g = p[tt];
while (g) {
e[g ].v -= flow;
e[g^].v += flow;
ans += e[g].cost * flow;
g = p[ e[g].a ];
}
tl += flow;
} void init() {
memset(head,,sizeof(head));
memset(e,,sizeof(e));
memset(d,,sizeof(d)); //memset(qlr,0,sizeof(qlr));
//memset(qrr,0,sizeof(qrr));
//memset(qlc,0,sizeof(qlc));
//memset(qrc,0,sizeof(qrc)); memset(sc,,sizeof(sc));
memset(sr,,sizeof(sr));
memset(c,,sizeof(c));
memset(r,,sizeof(r));
memset(map,,sizeof(map));
cnt = ; tot = ;
S = ++tot; T = ++tot; add_Node(T,S,,INF,);
ans = tl = ;
} int main() {
#ifndef ONLINE_JUDGE
freopen("5.in","r",stdin);
#endif
while (~scanf("%d",&n)) {
init();
for (int i=;i<=n;i++) for (int j=;j<=n;j++) {
scanf("%d",&map[i][j]);
if (map[i][j]) sr[i]++ ,sc[j]++;
}
for (int i=;i<=n;i++) r[i] = ++tot , c[i] = ++tot;
for (int i=;i<=n;i++) {
scanf("%d%d",&qlr[i],&qrr[i]);
add_Node(S,r[i],sr[i],sr[i],); //³¬¼¶Ô´ --> µÚiÐÐ
add_Node(r[i],T,qlr[i],qrr[i],); //µÚiÐÐ --> ³¬¼¶»ã
}
for (int i=;i<=n;i++) {
scanf("%d%d",&qlc[i],&qrc[i]);
add_Node(S,c[i],sc[i],sc[i],); //³¬¼¶Ô´ --> µÚiÁÐ
add_Node(c[i],T,qlc[i],qrc[i],); //µÚiÁÐ --> ³¬¼¶»ã
}
for (int i=;i<=n*n/;i++) {
int x1,y1,x2,y2;
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
if (map[x1][y1] == map[x2][y2]) continue;
if (!map[x1][y1]) swap(x1,x2) , swap(y1,y2);
if (x1 == x2) add_Node(c[y1],c[y2],,,); //Èç¹ûÔÚͬһÐÐ ¾ÍÔÚÁÐÖ®¼äÁ¬±ß
if (y1 == y2) add_Node(r[x1],r[x2],,,); //Èç¹ûÔÚͬһÁÐ ¾ÍÔÚÐÐÖ®¼äÁ¬±ß
}
paul(); //²¹ÉÏËùÓвðµÄ±ß //for (int i=2;i<=cnt;i+=2) if (e[i].v) printf("%d %d %d %d\n",e[i].a,e[i].b,e[i].v,e[i].cost); while (SPFA())
mcf();
//for (int i=3;i<=cnt;i+=2) if (e[i].v) printf("%d %d %d\n",e[i].b,e[i].a,e[i].v); for (int i=head[ss];i;i=e[i].next) if (e[i].v) ans = -;//ÅжÏÊÇ·ñÓнâ
if (ans == -) puts("-1"); else printf("%d\n",ans);
}
return ;
}

UvaL-7670 上下界可行费用流的更多相关文章

  1. 【UVALive - 5131】Chips Challenge(上下界循环费用流)

    Description A prominent microprocessor company has enlisted your help to lay out some interchangeabl ...

  2. 【BZOJ-4213】贪吃蛇 有上下界的费用流

    4213: 贪吃蛇 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 58  Solved: 24[Submit][Status][Discuss] Desc ...

  3. BZOJ2055 80人环游世界 网络流 费用流 有源汇有上下界的费用流

    https://darkbzoj.cf/problem/2055 https://blog.csdn.net/Clove_unique/article/details/54864211 ←对有上下界费 ...

  4. BZOJ 2055: 80人环游世界(有上下界的费用流)

    题面 Time Limit: 10 Sec Memory Limit: 64 MB Submit: 693 Solved: 434 [Submit][Status][Discuss] Descript ...

  5. 【上下界网络流 费用流】bzoj2055: 80人环游世界

    EK费用流居然写错了…… Description     想必大家都看过成龙大哥的<80天环游世界>,里面的紧张刺激的打斗场面一定给你留下了深刻的印象.现在就有这么     一个80人的团 ...

  6. Codeforces Gym 101190 NEERC 16 .D Delight for a Cat (上下界的费用流)

    ls是一个特别堕落的小朋友,对于n个连续的小时,他将要么睡觉要么打隔膜,一个小时内他不能既睡觉也打隔膜 ,因此一个小时内他只能选择睡觉或者打隔膜,当然他也必须选择睡觉或打隔膜,对于每一个小时,他选择睡 ...

  7. BZOJ 3876 支线剧情 有源汇有上下界最小费用可行流

    题意: 给定一张拓扑图,每条边有边权,每次只能从第一个点出发沿着拓扑图走一条路径,求遍历所有边所需要的最小边权和 分析: 这道题乍一看,可能会想到什么最小链覆盖之类的,但是仔细一想,会发现不行,一是因 ...

  8. BZOJ 2055 80人环游世界 有上下界最小费用可行流

    题意: 现在有这么一个m人的团伙,也想来一次环游世界. 他们打算兵分多路,游遍每一个国家.    因为他们主要分布在东方,所以他们只朝西方进军.设从东方到西方的每一个国家的编号依次为1...N.假若第 ...

  9. [BZOJ2055]80人环游世界 有上下界最小费用最大流

    2055: 80人环游世界 Time Limit: 10 Sec  Memory Limit: 64 MB Description     想必大家都看过成龙大哥的<80天环游世界>,里面 ...

随机推荐

  1. Web jsp开发学习——dbcp jsp连接MySQL出现中文乱码解决

    开发过程中,通过dbcp.properties连接MySQL数据库,向数据库中插入中文字符时,出现乱码情况. 通过查阅资料,发现出现乱码的原因:MySQL数据库使用的是UTF-8编码,而dbcp.pr ...

  2. 物料主数据批导bapi

    创建物料主数据,根据模板不同批导原材料,半成品,成品.可根据实际需求对字段进行增删. report zmmr_bapi_mm01 no standard page HEADING. type-POOL ...

  3. 2019.05.30 S4 BUPT BP 客户增强说明

    - 看了一圈,发现网上BUPT增强的很少,有的也是做一个字段的页签的增强,我自己花时间研究了一下,在BP增加新的interface 界面按钮. BP页签增强部分就不写了,大家看链接吧 加上如何做出新的 ...

  4. ubuntu安装成功之后需要做些什么?

    1.安装VMtool 1.1打开虚拟机之后-> 安装VMtool 1.2 点击之后,桌面就会出现一个VMtool光驱文件,如果提示光驱被占用就先用root登录 1.3在命令行挂载 sudo mo ...

  5. H5中调起微信这么实现,如果未安装则提示未安装

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name ...

  6. python-Web-django-qq扫码登陆

    1.建路由 2.写qq登录的a链接 3 在控制器的loginQq的方法:拼接url,跳转到这个url: 去:https://graph.qq.com/oauth2.0/authorize?respon ...

  7. MaxScale中间件部署数据库读写分离

    操作系统:CentOS7 (Core) 数据库:MariaDB-10.2.6-linux-glibc_214-x86_64 MaxScale服务器:192.168.40.134 主服务器:192.16 ...

  8. configparser模块,subprocess 模块,xlrd,xlwt ,xml 模块,面向对象

    1. configparser模块 2.subprocess 模块 3.xlrd,xlwt 4.xml 模块 5.面向对象 面向对象是什么? 是一种编程思想,指导你如何更好的编写代码 关注点在对象 具 ...

  9. 【AMAD】beaker -- 用于session和缓存的WSGI中间件

    简介 动机 作用 个人评分 简介 Beaker1是一个web session和通用缓存库,并且包含一个WSGI中间件可以用于你的web应用. 动机 Beaker是基于MyghtyUtils2(一个古老 ...

  10. 《0day安全-软件漏洞分析技术》实验笔记2

    实验 3.4 通用shellcode 工具 Windows XP SP3 Visual C++ 6.0 OD IDA 源代码 见随书代码,参考:https://github.com/jas502n/0 ...