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 ...
随机推荐
-
一个简单的Webservice的demo,简单模拟服务
前段时间一直在学习WCF,匆匆忙忙的把<WCF全面解析>和<WCF服务编程>看了一遍,好多东西都不是很懂,又听了一下WCF分布式开发的网络教程,算是马马虎虎的明白点了.回顾了一 ...
-
20145212 《Java程序设计》第2周学习总结
20145212 <Java程序设计>第2周学习总结 教材学习内容总结 第二周主要学习了Java的基本语法,在第一周熟悉了Java基本操作的基础上我们可以自行的利用这些语法编译具有实用价值 ...
-
Pyqt 获取windows系统中已安装软件列表
开始之前的基础知识 1. 获取软件列表 在Python的标准库中,_winreg可以操作Windows的注册表.获取已经安装的软件列表一般是读去windows的注册表: SOFTWARE\Micros ...
-
【CUDA学习】全局存储器
全局存储器,即普通的显存,整个网格中的任意线程都能读写全局存储器的任意位置. 存取延时为400-600 clock cycles 非常容易成为性能瓶颈. 访问显存时,读取和存储必须对齐,宽度为4By ...
-
leetcode 121. Best Time to Buy and Sell Stock ----- java
Say you have an array for which the ith element is the price of a given stock on day i. If you were ...
-
[置顶] 深入理解android之IPC机制与Binder框架
[android之IPC机制与Binder框架] [Binder框架.Parcel.Proxy-Stub以及AIDL] Abstract [每个平台都会有自己一套跨进程的IPC机制,让不同进程里的两个 ...
-
QT5-控件-QComboBox
#ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include <QComboBox> cl ...
-
创建存储过程 in,out,inout
in: 输入参数,存储过程如果修改了参数值,那么不能被返回. out:输出参数,存储过程中修改了参数值,可以被返回.inout:输入参数,存储过程如果修改了参数值,可以被返回 注意参数格式: in ...
-
BZOJ 2728: [HNOI2012]与非(位运算)
题意 定义 NAND(与非)运算,其运算结果为真当且仅当两个输入的布尔值不全为真,也就是 A NAND B = NOT(A AND B) ,运算位数不会超过 \(k\) 位, 给你 \(n\) 个整数 ...
-
VMware虚拟机克隆CentOS 6.5后网卡修改方法
VMware虚拟机安装好CentOS6.5系统后,纯净的系统多克隆几份出来方便后期做试验.克隆步骤很简单,克隆后出现的问题是克隆后的网卡MAC地址和原系统MAC地址一样,在局域网内会有冲突,需要更改克 ...