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 题目 匪徒准备从一个车站转移毒品到另一个车站,警方准备进行布控. 对于每个车站进行布控都需要一定的代价,现在警方希望使用最小的代价控制一些车站,使得去掉这些车站后, ...
随机推荐
- 4、手把手教React Native实战之flexbox布局(伸缩属性)
###伸缩项目的属性 1.order 定义项目的排列顺序,数值越小,排列越靠前,默认值为0,语法为:order:整数值 2.flex-grow 定义伸缩项目的放大比例,默认值为0,即表示如果存在剩余空 ...
- 关于 HTML5 的文件上传处理,兼容性问题,以及 BLOB 对象的使用 (转载)
研究过程中关于本主体的相关参考 好文:https://hacks.mozilla.org/2011/01/how-to-develop-a-html5-image-uploader/ 好文:http: ...
- 54、Android 粒子效果之雨(下雨的效果)
核心内容: 1.绘制下雨场景的个体.雨点(直线) 2.让直线动起来 3.处理边界问题 4.构造雨点对象 5.雨点大小设置 6.速度设置和角度设置等 7.添加多个雨点 8.抽离可以在 XML 中影响的属 ...
- darknet(yolov2)移植到caffe框架
yolov2到caffe的移植主要分两个步骤:一.cfg,weights转换为prototxt,caffemodel1.下载源码:git clone https://github.com/marvis ...
- Django开发流程
1.创建Django工程 django-admin startproject pro1 2.settings.py配置中文和时区,和在pro1根目录下创建一个'static'目录,并在settings ...
- 在Editplus中Dev C++配置C++的编译运行环境
1.首先得下载安装DEV-cpp 2.打开Editplus编辑器,工具->配置自定义工具 3.具体配置 编译C:命令:D:\Dev-Cpp\MinGW64\bin\g++.exe参数:" ...
- 如何设置,使IntelliJ IDEA智能提示忽略大小写
- linux必学
memcache zookeeper activemq
- MySQL中的共享锁与排他锁
MySQL中的共享锁与排他锁 在MySQL中的行级锁,表级锁,页级锁中介绍过,行级锁是Mysql中锁定粒度最细的一种锁,行级锁能大大减少数据库操作的冲突.行级锁分为共享锁和排他锁两种,本文将详细介绍共 ...
- 标准编译安装(configure make)
./configure --prefix=安装目录 这里注意,安装目录可以自己选择地方,但是自己选择地方的话就要把编译出的bin.include.lib三个文件夹分别加入XXX XXX XXX三个 ...