[bzoj 2768]&[bzoj 1877]
传送门1
传送门1
Solution
两道比较裸的题。。。
复习一下最大流和费用流的模板。
Code[bzoj 2768][JLOI 2010] 冠军调查
#include<bits/stdc++.h>
#define ll long long
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
#define MN 505
#define T 500
#define S 0
#define ME 200000
#define inf 0x3f3f3f3f
struct edge{int to,w,nex;}e[ME];
int hr[MN],cur[MN],en=1;
inline void ins(int f,int t,int w)
{
e[++en]=(edge){t,w,hr[f]};hr[f]=en;
e[++en]=(edge){f,0,hr[t]};hr[t]=en;
}
int d[MN],q[MN],top;
bool bfs()
{
memset(d,0,sizeof d);
register int i,j;
for(d[q[i=top=1]=S]=1;i<=top;++i)
for(j=hr[q[i]];j;j=e[j].nex)
if(e[j].w&&!d[e[j].to])
d[q[++top]=e[j].to]=d[q[i]]+1;
return d[T];
}
int dfs(int x,int f)
{
if(x==T) return f;
int used=0,w;
for(int i=cur[x];i;i=e[i].nex)
{
cur[x]=i;
if(d[e[i].to]==d[x]+1&&e[i].w)
{
w=dfs(e[i].to,min(e[i].w,f-used));
used+=w;e[i].w-=w;e[i^1].w+=w;
if(f==used) return used;
}
}
return d[x]=-1,used;
}
int ans=0;
void solve()
{
while(bfs())
{
memcpy(cur,hr,sizeof cur);
ans+=dfs(S,inf);
}
}
int main()
{
register int i,x,y,n=read(),m=read();
for(i=1;i<=n;++i) read()?ins(S,i,1):ins(i,T,1);
while(m--) x=read(),y=read(),ins(x,y,1),ins(y,x,1);
solve();return 0*printf("%d\n",ans);
}
Code[bzoj 1877][SDOI 2009]晨跑
#include<bits/stdc++.h>
#define ll long long
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
#define MN 505
#define ME 41000
#define inf 0x3f3f3f3f
struct edge{int to,w,c,nex;}e[ME];
int hr[MN],en=1,S,T;
inline void ins(int f,int t,int w,int c)
{
e[++en]=(edge){t,w,c,hr[f]}; hr[f]=en;
e[++en]=(edge){f,0,-c,hr[t]};hr[t]=en;
}
int d[MN],q[ME<<2],l,r;
bool inq[MN],vis[MN];
bool spfa()
{
memset(d,0x3f,sizeof d);
d[q[l=r=ME]=T]=0;inq[T]=true;
register int i;
while(l<=r)
{
int u=q[l++];inq[u]=false;
for(i=hr[u];i;i=e[i].nex)
if(e[i^1].w&&d[e[i].to]>d[u]-e[i].c)
{
d[e[i].to]=d[u]-e[i].c;
if(inq[e[i].to]) continue;
inq[e[i].to]=true;
d[e[i].to]<=d[q[l]]?q[--l]=e[i].to:q[++r]=e[i].to;
}
}
return d[S]!=inf;
}
ll mincost=0,maxflow=0;
int dfs(int x,int f)
{
vis[x]=true;
if(x==T) return f;
int used=0,w;
for(int i=hr[x];i;i=e[i].nex)
if(e[i].w&&d[e[i].to]+e[i].c==d[x]&&!vis[e[i].to])
{
w=dfs(e[i].to,min(e[i].w,f-used));
used+=w;e[i].w-=w;e[i^1].w+=w;
mincost+=1ll*w*e[i].c;
if(used==f) return f;
}
return used;
}
void solve()
{
while(spfa())
{
do
{
memset(vis,0,sizeof vis);
maxflow+=dfs(S,inf);
}while(vis[T]);
}
}
int main()
{
register int x,y,c,N=read(),M=read(),i;
for(i=1;i<=N;++i) ins(i,i+N,1,0);
while(M--) x=read(),y=read(),c=read(),ins(x+N,y,1,c);
S=1+N;T=N;
solve();return 0*printf("%lld %lld\n",maxflow,mincost);
}
Blog来自PaperCloud,未经允许,请勿转载,TKS!
[bzoj 2768]&[bzoj 1877]的更多相关文章
- 【BZOJ】【1877】【SDOI2009】晨跑
网络流/费用流 费用流入门题……根本就是模板题好吗! 拆点搞定度数限制,也就是每个点最多经过一次……源点汇点除外. /***************************************** ...
- BZOJ 2768 冠军调查(最小割)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2768 题意:给出一个无向图,每个点有一个值0或者1.现在重新设置每个点的值0或者1.设重 ...
- BZOJ 2768: [JLOI2010]冠军调查 最小割
2768: [JLOI2010]冠军调查 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2768 Description 一年一度的欧洲足 ...
- [BZOJ 2768] 冠军调查
Link:https://www.lydsy.com/JudgeOnline/problem.php?id=2768 Solution: 一道比较基础的最大流的题目 一般看到将点分为两类的题目就要往网 ...
- bzoj 2768: [JLOI2010]冠军调查
#include<cstdio> #include<iostream> #define M 100000 #include<cstring> using names ...
- BZOJ 3270 && BZOJ 1778 (期望DP && 高斯消元)
BZOJ 3270 :设置状态为Id(x,y)表示一人在x,一人在y这个状态的概率. 所以总共有n^2种状态. p[i]表示留在该点的概率,Out[i]=(1-p[i])/Degree[i]表示离开该 ...
- BZOJ 2002 && BZOJ 2409 LCT && BZOJ 3282 初步练习
#include <cstdio> ; inline void Get_Int(int & x) { ; ') ch=getchar(); +ch-'; ch=getchar(); ...
- BZOJ 3670 && BZOJ 3620 && BZOJ 3942 KMP
最近感到KMP不会啊,以前都是背板的现在要理解了. #include <iostream> #include <cstring> #include <cstdio> ...
- [PA2014] [BZOJ 3709]~[BZOJ 3719] 合集
今天起尝试做套题喵~ (当然是因为被最大流的题目弄得恶心死了) 一共是 10 道题一道一道做 预计 3~4 内做完 尽情期待 [BZOJ 3709]Bohater 一眼就能感受到贪心的气息 因为很直观 ...
随机推荐
- ABP 基于DDD的.NET开发框架 学习(五)中使用DevExpress插件
1.DevExpress安装 安装步骤1:开始安装 安装步骤2:选择需要安装的模块 安装步骤3:修改安装路径 安装步骤4:正在安装 安装步骤5:安装完成 2.Vs中设置 1)DevExtremeBun ...
- 写在NOIP2018前
不知不觉距离NOIP2018还有两天,两个月的停课生活即将结束 此时心里总感觉装着许多话,想要将其倾诉却发现连哪怕一句也凝结不出 只觉得这两月像是场荒诞的冒险,好像我想做的什么都做了,又感觉我其实一事 ...
- SqlServer2008 / SqlServer2012 禁用windows登录,sa忘记密码或密码过期如何登陆
以管理员身份运行cmd 1.cmd 下 停止SqlServer服务,net stop mssqlserver: 2.新建windows账号test,加入administrators组里,授予管理员权 ...
- 数据结构之队列(queue)
队列介绍 1.队列是一个有序列表,可以用数组或是链表来实现. 2.遵循先入先出的原则.即:先存入队列的数据,要先取出.后存入的要后取出. 应用场景 比如某某银行叫号系统: 数组模拟队列 队列本身是有序 ...
- [转发]C++中new和malloc的区别
原文地址:https://blog.csdn.net/linux_ever/article/details/50533149 new与malloc的10点区别 1. 申请的内存所在位置 new操作符从 ...
- jQuery标签操作
样式操作 样式类操作 //添加指定的css类名 $('元素选择器')addClass('类名'); //移除指定的css类名 removeClass(); //判断样式存不存在 hasClass(); ...
- java保证多线程的执行顺序
1. java多线程环境中,如何保证多个线程按指定的顺序执行呢? 1.1 通过thread的join方法保证多线程的顺序执行, wait是让主线程等待 比如一个main方法里面先后运行thread1, ...
- Session机制详解及分布式中Session共享解决方案
一.为什么要产生Session http协议本身是无状态的,客户端只需要向服务器请求下载内容,客户端和服务器都不记录彼此的历史信息,每一次请求都是独立的. 为什么是无状态的呢?因为浏览器与服务器是使用 ...
- Dockerfile的编写(主观汇聚篇)
目录 一.什么是dockerfile 二.Dockerfile的基本结构 Dockerfile文件说明 三.总结 一.什么是dockerfile dockerfile是使用者用来自定义构建一个dock ...
- HTTP 协议部分常识简介
1.状态码 具体的状态码可以百度查找,但是对于状态码的大致分类有一个清楚的了解 1XX ----信息状态码------接受的请求正在处理 2XX ------成功状态码 ------请求正常处理完 ...