1163: [Baltic2008]Mafia
1163: [Baltic2008]Mafia
Time Limit: 10 Sec Memory Limit: 162 MB
Submit: 123 Solved: 70
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
5 3
2
4
8
3
10
1 5
1 2
2 4
4 5
2 3
3 4
Sample Output
HINT
Source
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL inf=0x3f3f3f3f;
const LL maxn=;
const LL maxm=;
struct Edge{
LL to;//这条边通向的点
LL rest;//这条变的权值
LL next;//与这条边相连的上一条边
};
Edge edge[maxn];//edge[i]代表一条有向边
LL head[maxm];
LL ecnt=;
inline void AddEdge(LL x,LL y,LL r){
edge[++ecnt].to=y; edge[ecnt].rest=r; edge[ecnt].next=head[x]; head[x]=ecnt;
edge[++ecnt].to=x; edge[ecnt].rest=; edge[ecnt].next=head[y]; head[y]=ecnt;
}
LL N,M,S,T;
LL dis[maxn]; inline bool BFS(){
memset(dis,,sizeof(dis));
dis[S]=;
static queue<LL> Q;
while(Q.size()>) Q.pop();
Q.push(S);
while(Q.size()>){
LL x=Q.front(); Q.pop();
for(LL e=head[x] ; e ; e=edge[e].next){//e表示的是边,不是点
LL d=edge[e].to;
if(edge[e].rest&&dis[d]==){//边权不为零且这条边通向的点的
dis[d]=dis[x]+;
Q.push(d);
if(d==T) return true;
}
}
}
return false;
} inline LL DFS(LL x,LL flow){
if(x==T) return flow;
LL now=,tmp;
for(LL e=head[x]; e ;e=edge[e].next){
if(edge[e].rest&&dis[edge[e].to]==dis[x]+){
tmp=DFS(edge[e].to,min(flow-now,edge[e].rest));
edge[e].rest-=tmp;
edge[e ^ ].rest+=tmp;
now+=tmp;
if(now==flow) return now;
}
}
return now;
}
inline LL dinic(){
LL ans=;
while(BFS()){
ans+=DFS(S,inf);
}
return ans;
}
LL money[maxn];
LL tot;
int main(){
cin>>N>>M;
cin>>S>>T;
T+=N;
for(LL i=;i<=N;i++){
LL v;
cin>>v;
AddEdge(i,i+N,v);
}
for(LL i=;i<=M;i++){
LL u,v;
cin>>u>>v;
AddEdge(u+N,v,inf);
AddEdge(v+N,u,inf);
}
cout<<dinic();
return ;
}
第二种:
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL inf=0x3f3f3f3f;
const LL maxn=;
const LL maxm=;
struct Edge{
LL to;//这条边通向的点
LL rest;//这条变的权值
LL next;//与这条边相连的上一条边
};
Edge edge[maxm];//edge[i]代表一条有向边
LL head[maxm];
LL ecnt=;
inline void AddEdge(LL x,LL y,LL r){
edge[++ecnt].to=y; edge[ecnt].rest=r; edge[ecnt].next=head[x]; head[x]=ecnt;
edge[++ecnt].to=x; edge[ecnt].rest=; edge[ecnt].next=head[y]; head[y]=ecnt;
}
LL N,M,S,T;
LL dis[maxn]; inline bool BFS(){
memset(dis,,sizeof(dis));
dis[S]=;
static queue<LL> Q;
while(Q.size()>) Q.pop();
Q.push(S);
while(Q.size()>){
LL x=Q.front(); Q.pop();
for(LL e=head[x] ; e ; e=edge[e].next){//e表示的是边,不是点
LL d=edge[e].to;
if(edge[e].rest&&dis[d]==){//边权不为零且这条边通向的点的
dis[d]=dis[x]+;
Q.push(d);
if(d==T) return true;
}
}
}
return false;
} inline LL DFS(LL x,LL flow){
if(x==T) return flow;
LL now=,tmp;
for(LL e=head[x]; e ;e=edge[e].next){
if(edge[e].rest&&dis[edge[e].to]==dis[x]+){
tmp=DFS(edge[e].to,min(flow-now,edge[e].rest));
edge[e].rest-=tmp;
edge[e ^ ].rest+=tmp;
now+=tmp;
if(now==flow) return now;
}
}
return now;
}
inline LL dinic(){
LL ans=;
while(BFS()){
ans+=DFS(S,inf);
}
return ans;
}
LL money[maxn];
LL tot;
int main(){
cin>>N>>M;
cin>>S>>T;
for(LL i=;i<=N;i++) scanf("%d",&money[i]);
for(LL i=;i<=N;i++){
tot++;
AddEdge(tot,tot+,money[i]);
tot++;
}
for(LL i=;i<=M;i++){
LL r,l;
cin>>r>>l;
LL rr,ll;
rr=(r-)*+;//出点
ll=(l-)*+;//入点
AddEdge(rr,ll,inf);
ll++;
rr--;
AddEdge(ll,rr,inf);
}
S=(S-)*+;
T=(T-)*+;
cout<<dinic();
return ;
}
1163: [Baltic2008]Mafia的更多相关文章
- 1339 / 1163: [Baltic2008]Mafia
1163: [Baltic2008]Mafia Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 96 Solved: 60[Submit][Statu ...
- bzoj1339/1163:[Baltic2008]Mafia
传送门 最小割,割点,模板... 代码: #include<cstdio> #include<iostream> #include<algorithm> #incl ...
- [BZOJ1163][BZOJ1339][Baltic2008]Mafia
[BZOJ1163][BZOJ1339][Baltic2008]Mafia 试题描述 匪徒准备从一个车站转移毒品到另一个车站,警方准备进行布控. 对于每个车站进行布控都需要一定的代价,现在警方希望使用 ...
- bzoj1339[Baltic2008]Mafia*
bzoj1339[Baltic2008]Mafia 题意: 匪徒准备从一个车站转移毒品到另一个车站,警方准备进行布控.对于每个车站进行布控都需要一定的代价,现在警方希望使用最小的代价控制一些车站,使得 ...
- BZOJ1163&BZOJ1339[Baltic2008]Mafia——最小割
题目描述 匪徒准备从一个车站转移毒品到另一个车站,警方准备进行布控. 对于每个车站进行布控都需要一定的代价,现在警 方希望使用最小的代价控制一些车站,使得去掉这些车站后,匪徒无法从原定的初始点到达目标 ...
- [BZOJ1339] [Baltic2008] Mafia / 黑手党
Description 匪徒准备从一个车站转移毒品到另一个车站,警方准备进行布控. 对于每个车站进行布控都需要一定的代价, 现在警方希望使用最小的代价控制一些车站,使得去掉这些车站后,匪徒无法从原定的 ...
- 【bzoj1163/bzoj1339】[Baltic2008]Mafia 网络流最小割
题目描述 匪徒准备从一个车站转移毒品到另一个车站,警方准备进行布控. 对于每个车站进行布控都需要一定的代价,现在警方希望使用最小的代价控制一些车站,使得去掉这些车站后,匪徒无法从原定的初始点到达目标点 ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- [BZOJ1163&1339]Mafia
[Baltic2008]Mafia 题目 匪徒准备从一个车站转移毒品到另一个车站,警方准备进行布控. 对于每个车站进行布控都需要一定的代价,现在警方希望使用最小的代价控制一些车站,使得去掉这些车站后, ...
随机推荐
- <转载> C++笔试、面试笔记
这些东西有点烦,有点无聊.如果要去C++面试就看看吧.几年前网上搜索的.刚才看到,就整理一下,里面有些被我改了,感觉之前说的不对或不完善. 1.求下面函数的返回值( 微软) int func(x) ...
- mysql连接远程数据库的用法
mysql -u root -p 等这些常用的参数外,你知道多少?来测试一下吧 一,mysql命令行参数 Usage: mysql [OPTIONS] [database] //命令方式 -?, ...
- 巨蟒python全栈开发-第7天 基本数据类型补充&深浅拷贝
1.基本数据类型补充 2.深浅拷贝 DAY7-基本数据类型(基本数据类型补充&深浅拷贝) 本节主要内容: 1.补充基础数据类型 (1)join方法 (2)split方法 (3)列表不能在循环时 ...
- Oracle-Rman(物理备份)
Rman(物理备份) Rman -recover manager Rman 备份的对象 数据文件 数据文件 (Data File) 控制文件 控制文件 (Control File) 参数文件 参数文件 ...
- 3 CActiveXUI的一个Bug
如果主窗口直接用变量生成,则关闭窗口时会产生崩溃 如果用new的方式生成,则不会崩溃,所以给出一个临时的快速解决方案,即主窗口都用new生成,_tWinMain改为下面这样: i ...
- Python菜鸟之路:Django 分页
Django的分页没有多少需要说的,有一点需要关注,在自定制分页功能的时候,需要通过python代码来生成每一页的a标签链接,这个时候需要关注一点:默认情况下,为了安全考虑,防范XSS攻击,Djang ...
- Python 模块之 xlrd (Excel文件读写)
# 1. 导入模块 import xlrd # 2.打开Excel文件读取数据 data = xlrd.open_workbook('excelFile.xls') # 3. 使用技巧 # 3.1 获 ...
- java 遍历map的方法
package com.jackey.topic; import java.util.ArrayList;import java.util.HashMap;import java.util.Itera ...
- mui请求数据
var rh = new Object(); rh.ReqId = "ls123"; rh.Salt = "sssseee"; var rb = new Obj ...
- MYSQL SET ENUM字段类型
show create table stu;//显示建表语句 create table t1(t enum('a','b','c')); insert into t1 values('a'); cre ...