BZOJ 2200--[Usaco2011 Jan]道路和航线(最短路&拓扑排序)
2200: [Usaco2011 Jan]道路和航线
Time Limit: 10 Sec Memory Limit: 259 MB
Submit: 1128 Solved: 414
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 2 5
3 4 5
5 6 10
3 5 -100
4 6 -100
1 3 -10
样例输入解释:
一共六个城镇。在1-2,3-4,5-6之间有道路,花费分别是5,5,10。同时有三条航线:3->5,
4->6和1->3,花费分别是-100,-100,-10。FJ的中心城镇在城镇4。
Sample Output
NO PATH
5
0
-95
-100
样例输出解释:
FJ的奶牛从4号城镇开始,可以通过道路到达3号城镇。然后他们会通过航线达到5和6号城镇。
但是不可能到达1和2号城镇。
题目链接:
http://www.lydsy.com/JudgeOnline/problem.php?id=2200
Solution
有负权边,所以不能直接dijkstra。。而spfa已经死了。。。
但是题目保证“航线”不会出现在环里,所以如果把“道路”联结的点都缩起来就会变成一个DAG。。。
考虑一个只由道路联结的块,此时可以直接dijkstra。。。
DAG上就可以用拓扑排序的方法排除负权的影响,然后就没有然后了。。
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#include<vector>
#include<map>
#define pa pair<int,int>
#define LL long long
using namespace std;
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*10+ch-'0';ch=getchar();}
return x*f;
}
inline void Out(int a){
if(a>9) Out(a/10);
putchar(a%10+'0');
}
const int inf=1e9+10;
const LL mod=1e9+7;
const int N=2e5+50;
int n,m1,m2,S,cnt,CNT,blo;
int hed[N],HED[N],dis[N],bel[N],du[N];
struct edge{
int r,nxt,val;
}e[N];
void insert(int u,int v,int w){
e[++cnt].r=v;e[cnt].nxt=hed[u];hed[u]=cnt;e[cnt].val=w;
}
struct EDGE{
int r,nxt,val;
}E[N];
void INSERT(int u,int v,int w){
E[++CNT].r=v;E[CNT].nxt=HED[u];HED[u]=CNT;E[CNT].val=w;
}
int q[N];
priority_queue< pa ,vector< pa >,greater< pa > >PQ;
bool vis[N];
vector<int> ve[N];
void dfs(int x,int c){
bel[x]=c;
ve[c].push_back(x);
for(int i=hed[x];i;i=e[i].nxt)
if(!bel[e[i].r]) dfs(e[i].r,c);
}
int main(){
n=read();m1=read();m2=read();S=read();
for(int i=1;i<=n;++i) dis[i]=inf;
int u,v,w;
for(int i=1;i<=m1;++i){
u=read();v=read();w=read();
insert(u,v,w);
insert(v,u,w);
}
for(int i=1;i<=m2;++i){
u=read();v=read();w=read();
INSERT(u,v,w);
}
for(int i=1;i<=n;++i)
if(!bel[i]) dfs(i,++blo);
for(int i=1;i<=n;++i)
for(int j=HED[i];j;j=E[j].nxt)
++du[bel[E[j].r]];
int l=1,r=0,x;
for(int i=1;i<=blo;++i)
if(!du[i]) q[++r]=i;
dis[S]=0;
while(l<=r){
x=q[l++];
for(int i=0;i<ve[x].size();++i){
if(dis[ve[x][i]]<inf)
PQ.push(make_pair(dis[ve[x][i]],ve[x][i]));
}
while(!PQ.empty()){
u=PQ.top().second;
w=PQ.top().first;
PQ.pop();
if(vis[u])continue;
else vis[u]=1;
for(int i=hed[u];i;i=e[i].nxt)
if(dis[e[i].r]>dis[u]+e[i].val){
dis[e[i].r]=dis[u]+e[i].val;
PQ.push(make_pair(dis[e[i].r],e[i].r));
}
for(int i=HED[u];i;i=E[i].nxt)
if(dis[E[i].r]>dis[u]+E[i].val)
dis[E[i].r]=dis[u]+E[i].val;
}
for(int i=0;i<ve[x].size();++i){
for(int j=HED[ve[x][i]];j;j=E[j].nxt){
--du[bel[E[j].r]];
if(!du[bel[E[j].r]]) q[++r]=bel[E[j].r];
}
}
}
for(int i=1;i<=n;++i){
if(dis[i]==inf)
printf("NO PATH\n");
else printf("%d\n",dis[i]);
}
return 0;
}
This passage is made by Iscream-2001.
BZOJ 2200--[Usaco2011 Jan]道路和航线(最短路&拓扑排序)的更多相关文章
- [BZOJ 2200][Usaco2011 Jan]道路和航线 spfa+SLF优化
Description Farmer John正在一个新的销售区域对他的牛奶销售方案进行调查.他想把牛奶送到T个城镇 (1 <= T <= 25,000),编号为1T.这些城镇之间通过R条 ...
- bzoj 2200: [Usaco2011 Jan]道路和航线——拓扑+dijkstra
Description Farmer John正在一个新的销售区域对他的牛奶销售方案进行调查.他想把牛奶送到T个城镇 (1 <= T <= 25,000),编号为1T.这些城镇之间通过R条 ...
- BZOJ 2200: [Usaco2011 Jan]道路和航线
Description Farmer John正在一个新的销售区域对他的牛奶销售方案进行调查.他想把牛奶送到T个城镇 (1 <= T <= 25,000),编号为1T.这些城镇之间通过R条 ...
- bzoj 2200: [Usaco2011 Jan]道路和航线【spfa】
直接跑最短路就行了--还不用判负环 #include<iostream> #include<cstdio> #include<queue> using namesp ...
- 2200: [Usaco2011 Jan]道路和航线 (拓扑排序+dijstra)
Description Farmer John正在一个新的销售区域对他的牛奶销售方案进行调查.他想把牛奶送到T个城镇 (1 <= T <= 25,000),编号为1T.这些城镇之间通过R条 ...
- 【BZOJ】2200: [Usaco2011 Jan]道路和航线
[题意]给定n个点的图,正权无向边,正负权有向边,保证对有向边(u,v),v无法到达u,求起点出发到达所有点的最短距离. [算法]拓扑排序+dijkstra [题解]因为有负权边,直接对原图进行spf ...
- [Usaco2011 Jan]道路和航线
Description Farmer John正在一个新的销售区域对他的牛奶销售方案进行调查.他想把牛奶送到T个城镇 (1 <= T <= 25,000),编号为1T.这些城镇之间通过R条 ...
- bzoj2200: [Usaco2011 Jan]道路和航线
先忽略航线,求出图中所有连通块,再用航线拓扑排序求出每个连通块的优先级 然后dijkstra时优先处理优先级高的块里的点就行了 ps:这题SPFA会TLE #include <iostream& ...
- BZOJ 2199: [Usaco2011 Jan]奶牛议会
2199: [Usaco2011 Jan]奶牛议会 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 375 Solved: 241[Submit][S ...
随机推荐
- 【算法】DP解决旅行路径问题
问题描述 : After coding so many days,Mr Acmer wants to have a good rest.So travelling is the best choice ...
- 【搜索】 Prime Path
#include<cstdio> #include<cstring> #include<cmath> #include<queue> #include& ...
- C# WebService创建、发布、调用的简单例子
Web service是一个平台独立的,低耦合的,自包含的.基于可编程的web的应用程序,可使用开放的XML标准来描述.发布.发现.协调和配置这些应用程序,用于开发分布式的互操作的应用程序. Web ...
- tms web core 通过URL 传递参数
一般我们都会通过URL 给服务器传递很多参数,通过参数来决定对应的处理,今天就大概讲一下 如果通过URL 参数实现一些功能. 1.通过参数跳入不同的界面 首先我们先建立一个tms web core 工 ...
- bundler简介(ruby gem)
簡介 Bundler RubyGem 是包裝.散佈Ruby程式庫的標準方式,相關文件可以參考 RubyGems Guides 的說明,或是 簡介 plugins 中的第二個例子.在使用rails ...
- Firefox table 不居中解决办法 解决火狐层或 table 不居中
Firefox table 不居中解决办法: table 使用 align="center" ,IE正常,Firefox 却是居左了,网上有各种解决的办法,比如在table外面再套 ...
- sqlserver2008查询性能优化(文摘)
第1章 sql查询性能调整 第4章 索引分析
- CSS Sprites (CSS 精灵) 技术
CSS Sprites在国内很多人叫css精灵,是一种网页图片应用处理方式.它允许你将一个页面涉及到的所有零星图片都包含到一张大图中去,这样一来,当访问该页面时,载入的图片就不会像以前那样一幅一幅地慢 ...
- 研究生flag
是时候定个计划了,感觉日子一天天水,不加油学点东西,迟早要掉队…… 刷刷算法题库吧,貌似选几个管用的刷刷——https://hihocoder.com/problemset 争取明年三月份的PAT顶级 ...
- 第十四个目标 (fzu)
http://acm.fzu.edu.cn/contest/problem.php?cid=151&sortid=8 Problem Description 目暮警官.妃英里.阿笠博士等人接连 ...