题目描述

可可和卡卡家住合肥市的东郊,每天上学他们都要转车多次才能到达市区西端的学校。直到有一天他们两人参加了学校的信息学奥林匹克竞赛小组才发现每天上学的乘车路线不一定是最优的。
可可:“很可能我们在上学的路途上浪费了大量的时间,让我们写一个程序来计算上学需要的最少时间吧!”
合肥市一共设有N个公交车站,不妨将它们编号为1…N的自然数,并认为可可和卡卡家住在1号汽车站附近,而他们学校在N号汽车站。市内有M条直达汽车路线,执行第i条路线的公交车往返于站点pi和qi之间,从起点到终点需要花费的时间为ti。(1<=i<=M, 1<=piqi<=N)
两个人坐在电脑前,根据上面的信息很快就编程算出了最优的乘车方案。然而可可忽然有了一个鬼点子,他想趁卡卡不备,在卡卡的输入数据中删去一些路线,从而让卡卡的程序得出的答案大于实际的最短时间。而对于每一条路线i事实上都有一个代价ci:删去路线的ci越大卡卡就越容易发现这个玩笑,可可想知道什么样的删除方案可以达到他的目的而让被删除的公交车路线ci之和最小。
[任务]
编写一个程序:
l 从输入文件中读取合肥市公交路线的信息;
l 计算出实际上可可和卡卡上学需要花费的最少时间;
l 帮助可可设计一个方案,删除输入信息中的一些公交路线,使得删除后从家到学校需要的最少时间变大,而被删除路线的ci和最小;
l 向输出文件输出答案。

输入

输入文件中第一行有两个正整数NM,分别表示合肥市公交车站和公交汽车路线的个数。以下M行,每行(第i行,总第(i+1)行)用四个正整数描述第i条路线:piqiti,ci;具体含义见上文描述。

输出

输出文件最多有两行。
第一行中仅有一个整数,表示从可可和卡卡家到学校需要的最短时间。
第二行ci之和的最小值。

样例输入

6 7 1 2 1 3 2 6 1 5 1 3 1 1 3 4 1 1 4 6 1 1 5 6 1 2 1 5 1 4

样例输出

2 5

提示

2<=N<=500, 1<=M<=124 750, 1<=tici<=10 000
合肥市的公交网络十分发达,你可以认为任意两个车站间都可以通过直达或转车互相到达,当然如果在你提供的删除方案中,家和学校无法互相到达,那么则认为上学需要的最短为正无穷大:这显然是一个合法的方案。
 
先用SPFA跑出1到n的最短路,然后把满足最短路的边都选出来重新建图,最后跑一遍最小割,细节在于边有重复,容量要用+=.
具体看代码:
 #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的更多相关文章

  1. BZOJ 1266: [AHOI2006]上学路线route(最短路+最小割)

    第一问最短路.第二问,先把最短路的图建出来(边(u,v)满足d[s->u]+d[v->t]+d(u,v)==最短路径长度,就在图中,可以从源点和汇点分别跑一次最短路得到每个点到源点和汇点的 ...

  2. bzoj 1266 [AHOI2006] 上学路线 route 题解

    转载请注明:http://blog.csdn.net/jiangshibiao/article/details/23989499 [原题] 1266: [AHOI2006]上学路线route Time ...

  3. 洛谷 P4300 BZOJ 1266 [AHOI2006]上学路线route

    题目描述 可可和卡卡家住合肥市的东郊,每天上学他们都要转车多次才能到达市区西端的学校.直到有一天他们两人参加了学校的信息学奥林匹克竞赛小组才发现每天上学的乘车路线不一定是最优的. 可可:“很可能我们在 ...

  4. BZOJ 1266: [AHOI2006]上学路线route Floyd_最小割

    十分简单的一道题. 图这么小,跑一边 Floyd 就得到第一问最短路径的答案. 考虑第二问怎么求:我们可以先将最短路径组成的图从原图中抽离出来,构成新图 $G$. 我们发现,只要 $G$ 的起点与终点 ...

  5. bzoj 1266 1266: [AHOI2006]上学路线route

    1266: [AHOI2006]上学路线route Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 2356  Solved: 841[Submit][S ...

  6. [BZOJ 1266][AHOI2006]上学路线(最短路+最小割)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1266 分析: 很简单的题目,容易想到就是把所有的最短路径挑出来,然后在这个图里跑最小割 ...

  7. bzoj 1266 [AHOI2006] 上学路线

    传送门 传说中的经典容斥+卢卡斯定理+中国剩余定理 题解传送门 //Achen #include<algorithm> #include<iostream> #include& ...

  8. bzoj1266 [AHOI2006]上学路线route floyd建出最短路图+最小割

    1266: [AHOI2006]上学路线route Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 2490  Solved: 898[Submit][S ...

  9. bzoj1266 [AHOI2006]上学路线route floyd+最小割

    1266: [AHOI2006]上学路线route Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 2490  Solved: 898[Submit][S ...

随机推荐

  1. 20144306《网络对抗》MAL_逆向与Bof基础

    实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会简单回显任何用户输入的字符串. 该程序同时包含另一个代码片段,getShe ...

  2. 企业架构(TOGAF)学习

    自从听了公司内部的一堂<企业架构设计>培训,顿时觉得如获至宝. 先说下笔者,笔者是一名二流本科毕业,工作三年,基层的软件开发工程师,梦想着有朝一日成长成一名架构师.可是笔者对于如何成长成一 ...

  3. Webpack单元测试,e2e测试

    此篇文章是续 webpack多入口文件.热更新等体验,主要说明单元测试与e2e测试的基本配置以及相关应用. 一.单元测试 实现单元测试框架的搭建.es6语法的应用.以及测试覆盖率的引入. 1. 需要安 ...

  4. 功能总结之MongDB初探

    题外话 工作3年,了解的技术颇多,但都是一知半解,了解不是很透澈.用过的技术,就像猴子搬过的包谷,搬一个丢一个.几年风雨,真有点一缕清风过,片叶不沾身的味道. 为强化知识点,提升文档及学习能力,我把以 ...

  5. python自动化框架(unnitest+selenium+htmlreport)

    上一篇零零散散的写了一些python unnitest的一些知识,这里讲讲我在实际中使用到的自动化测试框架,算是上篇记录的补充!其实我觉得:什么框架都无所谓,关键是当如果用你的框架发现了bug,能尽量 ...

  6. iOS开发之URLSession

    1.概述 n  NSURLSession是iOS7中新的网络接口,与NSURLConnection是并列的. n  当程序在前台时,NSURLSession与NSURLConnection大部分可以互 ...

  7. Swift应用案例 2.闭包入门到精通

      本文主要介绍Swift的闭包的使用并与OC的Block做比较.学习Swift是绕不过闭包的,因为无论是全局函数还是嵌套函数都是闭包的一种,本文主要介绍闭包表达式. 1.闭包表达式的使用 // 1. ...

  8. instance 怎么获得自己的 Metadata - 每天5分钟玩转 OpenStack(169)

    要想从 nova-api-metadata 获得 metadata,需要指定 instance 的 id.但 instance 刚启动时无法知道自己的 id,所以 http 请求中不会有 instan ...

  9. iOS面试必看经典试题分析

    > **不用临时变量怎么实现两个数据的交换?** 方式一:加减法的运算方式求解new_b = a - b + b = a;new_a = a + b - a = b;一个简单的运算方式,最重要的 ...

  10. Uva 11609 Teams (组合数学)

    题意:有n个人,选不少于一个人参加比赛,其中一人当队长,有多少种选择方案. 思路:我们首先C(n,1)选出一人当队长,然后剩下的 n-1 人组合的总数为2^(n-1),这里用快速幂解决 代码: #in ...