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 题目 匪徒准备从一个车站转移毒品到另一个车站,警方准备进行布控. 对于每个车站进行布控都需要一定的代价,现在警方希望使用最小的代价控制一些车站,使得去掉这些车站后, ...
随机推荐
- js获取上个月的第一天和最后一天
var now = new Date(); var fd = new Date(now.getFullYear(), now.getMonth()-1 ,1).toLocaleDateString() ...
- iOS 保存异常日志
// // AppDelegate.m // test // // Created by Chocolate. on 14-4-16. // Copyright (c) 2014年 redasen. ...
- iOS UIModalPresentationFormSheet风格下的键盘隐藏
1. 在UIModalPresentationFormSheet(iPad device, without a UINavigationController)下的视图中,如果使用 [inputView ...
- 如何设置,使IntelliJ IDEA智能提示忽略大小写
- 深度扫盲O2O
http://www.ftchinese.com/interactive/5038?i=3 http://www.ftchinese.com/interactive/5038?i=3
- XXE(xml外部实体注入漏洞)
实验内容 介绍XXE漏洞的触发方式和利用方法,简单介绍XXE漏洞的修复. 影响版本: libxml2.8.0版本 漏洞介绍 XXE Injection即XML External Entity Inje ...
- caffe使用(1)
caffe使用 caffe是一个卓越的CNN框架 caffe源码是Cpp语言的,基于一些外部的库,包括BLAS(矩阵计算),CUDA(GPU驱动),gflags,glog,boost,protobuf ...
- Vue(3)- 安装脚手架、过滤器、生命周期的钩子函数、vue-router基本使用
一.安装脚手架 1.下载node.js,本文下载版本为node-v8.12.0-x64.msi,一键式安装. 2.安装完成后,打开终端,输入node,可进入node环境(两次ctrl+c退出),如下图 ...
- Python面向对象高级编程-_slots_
使用_slots_ 正常情况下,当定义一个class,创建一个class的实例后,可以给实例绑定任何属性和方法,这就是动态语言的灵活性.先定义class: >>> class Stu ...
- Python高级教程-生成器
生成器(Generator) 通过列表生成式,可以直接创建一个列表.但是,受内存限制,列表的容量肯定是有限的.而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几 ...