BZOJ 1266: [AHOI2006]上学路线route
题目描述
输入
输出
样例输入
样例输出
提示
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<vector>
using namespace std;
const int M=;
int gi()
{
int str=;char ch=getchar();
while(ch>'' || ch<'')ch=getchar();
while(ch>='' && ch<='')str=str*+ch-'',ch=getchar();
return str;
}
const int N=;
const int INF=;
int n,m;int q[M*];
struct Lin
{
int next,to,dis,ct;
}a[M*];
bool vis[N];int f[N][];
int num=;int head[N];
void init(int x,int y,int z,int ff)
{
a[++num].next=head[x];
a[num].to=y;
a[num].dis=z;
a[num].ct=ff;
head[x]=num;
}
void spfa(bool t,int sta)
{
int sum=,tail=;
vis[sta]=;
q[]=sta;
int x,u;
for(int i=;i<=n;i++)vis[i]=,f[i][t]=INF;
f[sta][t]=;
while(tail!=sum)
{
x=q[++tail];
for(int i=head[x];i;i=a[i].next)
{
u=a[i].to;
if(f[x][t]+a[i].dis<f[u][t])
{
f[u][t]=a[i].dis+f[x][t];
if(!vis[u])
{
q[++sum]=u;
vis[u]=true;
}
}
}
vis[x]=false;
}
}
int flow[N][N];
int dep[N];
bool bfs()
{
memset(dep,,sizeof(dep));
int t=,sum=;
dep[]=;
q[]=;
int x;
while(t!=sum)
{
x=q[++t];
for(int i=;i<=n;i++)
{
if(dep[i] || flow[x][i]<=)continue;
dep[i]=dep[x]+;
q[++sum]=i;
}
}
if(dep[n])
return true;
return false;
} int dfs(int x,int flows)
{
if(x==n || !flows)return flows;
int sum=,tmp;
for(int i=;i<=n;i++)
{
if(flow[x][i]<= || dep[i]!=dep[x]+)continue;
tmp=dfs(i,min(flows,flow[x][i]));
flow[x][i]-=tmp;
flow[i][x]+=tmp;
flows-=tmp;
sum+=tmp;
if(!flows)break;
}
return sum;
}
void work()
{
int cc=,tot=;
while(bfs()){
cc=;cc=dfs(,INF);
while(cc)tot+=cc,cc=dfs(,INF);
}
printf("%d",tot);
}
void build()
{
for(int i=;i<=n;i++){
for(int j=head[i];j;j=a[j].next){
if(f[n][]==f[a[j].to][]+f[i][]+a[j].dis)flow[i][a[j].to]+=a[j].ct;
}
}
}
int main()
{
n=gi();m=gi();
int x,y,z,ss;
for(int i=;i<=m;i++)
{
x=gi();y=gi();z=gi();ss=gi();
init(x,y,z,ss);init(y,x,z,ss);
}
spfa(,);
printf("%d\n",f[n][]);
spfa(,n);
build();
work();
return ;
}
BZOJ 1266: [AHOI2006]上学路线route的更多相关文章
- BZOJ 1266: [AHOI2006]上学路线route(最短路+最小割)
第一问最短路.第二问,先把最短路的图建出来(边(u,v)满足d[s->u]+d[v->t]+d(u,v)==最短路径长度,就在图中,可以从源点和汇点分别跑一次最短路得到每个点到源点和汇点的 ...
- bzoj 1266 [AHOI2006] 上学路线 route 题解
转载请注明:http://blog.csdn.net/jiangshibiao/article/details/23989499 [原题] 1266: [AHOI2006]上学路线route Time ...
- 洛谷 P4300 BZOJ 1266 [AHOI2006]上学路线route
题目描述 可可和卡卡家住合肥市的东郊,每天上学他们都要转车多次才能到达市区西端的学校.直到有一天他们两人参加了学校的信息学奥林匹克竞赛小组才发现每天上学的乘车路线不一定是最优的. 可可:“很可能我们在 ...
- BZOJ 1266: [AHOI2006]上学路线route Floyd_最小割
十分简单的一道题. 图这么小,跑一边 Floyd 就得到第一问最短路径的答案. 考虑第二问怎么求:我们可以先将最短路径组成的图从原图中抽离出来,构成新图 $G$. 我们发现,只要 $G$ 的起点与终点 ...
- bzoj 1266 1266: [AHOI2006]上学路线route
1266: [AHOI2006]上学路线route Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 2356 Solved: 841[Submit][S ...
- [BZOJ 1266][AHOI2006]上学路线(最短路+最小割)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1266 分析: 很简单的题目,容易想到就是把所有的最短路径挑出来,然后在这个图里跑最小割 ...
- bzoj 1266 [AHOI2006] 上学路线
传送门 传说中的经典容斥+卢卡斯定理+中国剩余定理 题解传送门 //Achen #include<algorithm> #include<iostream> #include& ...
- bzoj1266 [AHOI2006]上学路线route floyd建出最短路图+最小割
1266: [AHOI2006]上学路线route Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 2490 Solved: 898[Submit][S ...
- bzoj1266 [AHOI2006]上学路线route floyd+最小割
1266: [AHOI2006]上学路线route Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 2490 Solved: 898[Submit][S ...
随机推荐
- java中String s = new String("abc")创建了几个对象?
答案是两个,现在我们具体的说一下: String s = new String("abc");一.我们要明白两个概念,引用变量和对象,对象一般通过new在堆中创建,s只是一个引用变 ...
- Linux操作命令集
系统信息 arch 显示机器的处理器架构(1) uname -m 显示机器的处理器架构(2) uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS ...
- Linux学习之Vim使用
一 为何要学Vim 所有的Unix Like系统都有自带vi编辑器 一些软件的编辑接口会自动调起vi 作为vi的升级版,vim具有程序编辑功能,而且具有代码颜色高亮显示.辨别代码的正确性等功能 以上优 ...
- Android Things教程:电气基础之直流电路理论
译者注:由于本人水平有限,译文中难免会出现概念模糊.晦涩难懂,如果实在没心思看下去,请发挥你的学习能动性,到原文中自行翻译,感谢!!!点这里,直达英文各种长句的世界. 好了,既然你选择继续往下看,那就 ...
- PHPSTORM下安装XDEBUG
本文不是教程安装XDEBUG,具体的请自行百度(我也是按照百度上的一步步来的). 以下纠正几点目前我安装时查看播客的不对之处: 1. Setting > PHP > DEBUG > ...
- Linux下搭建mpi集群(ubuntu下用虚拟机测试)
一 建立SSH连接(无密码登陆) 1 SSH连接的简单介绍 SSH 为 Secure Shell 的缩写,中文翻译为安全外壳协议,建立在应用层,是一种远程连接安全协议.传统的telnet,pop,ft ...
- Luogu1486郁闷的出纳员【Splay】
P1486 郁闷的出纳员 题目描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反 ...
- 回答: 2017-03-19的关于css+div布局的疑问 2017-04-05
原问题为红色,回答为黑色 第一次布局一个静态网页,发现许多细节都需要自己探索,出现诸如以下问题: 1.布局问题:经常出现一个div被挤出来?做到一半少一个div布局? 布局之前,要点打好框架,明确每个 ...
- C# Task 源代码(2)
上篇已经讲到Task 的默认的TaskScheduler 为ThreadPoolTaskScheduler. 这时我们回到原来的task 的start方法,在代码最后,调用了 ScheduleAndS ...
- CF #405 (Div. 2) B. Bear ad Friendship Condition (dfs+完全图)
题意:如果1认识2,2认识3,必须要求有:1认识3.如果满足上述条件,输出YES,否则输出NO. 思路:显然如果是一个完全图就输出YES,否则就输出NO,如果是无向完全图则一定有我们可以用dfs来书边 ...