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 ...
随机推荐
- 【机器学习】感知机学习算法(PLA)
感知机问题学习算法引入:信用卡问题 根据已知数据(不同标准的人的信用评级)训练后得出一个能不能给新客户发放信用卡的评定结果 解决该问题的核心思想扔为之前所讲到的梯度下降算法,对于更多条件的类似问题,首 ...
- Mvvm Light 无法添加MvvmView(Win81)的问题
After I create a MvvmLight(Win81) project, I want add a new view , but there is only MvvmView(Win8), ...
- HttpMethods(C#.net)
HttpMethods (C#.Net) using System; using System.Collections.Generic; using System.Linq; using Syste ...
- android c 读写文件
1.包含头文件 #include<unistd.h>#include<sys/types.h>#include<sys/stat.h>#include<fcn ...
- chmod / chown /chattr
显示了七列信息,从左至右依次为:权限.文件数.归属用户.归属群组.文件大小.创建日期.文件名称 d :第一位表示文件类型 d 文件夹 - 普通文件 l 链接 b 块设备文件 p 管道文件 c 字符设备 ...
- php-fpm 的 pm.start_servers 参数调整
大家注意一下 在 php-fpm 的配置文件中, pm.start_servers 必须是介于 pm.min_spare_servers 和 pm.max_spare_servers 这个值之间 ...
- 关于SQL表字段值缺失的处理办法
在计算收益率时候, 收益率 = 收益 / 成本 一.如果成本为0,NULL,此时无法计算收益率: 方法: 1.将成本为0的数据 运算 (case when cost =0 or cost is n ...
- 学习node.js的C++扩展
本想买本书,可是太贵,了一下作者可惜没有回应,不然也会去支持一下.于是自己baidu罗.先是从这个入手 安装好环境 https://github.com/nodejs/node-gyp#install ...
- Android Studio自定义组合控件
在Android的开发中,为了能够服用代码,会把有一定共有特点的控件组合在一起定义成一个自定义组合控件. 本文就详细讲述这一过程.虽然这样的View的组合有一个粒度的问题.粒度太大了无法复用,粒度太小 ...
- python读取并写入mat文件
用matlab生成一个示例mat文件: clear;clc matrix1 = magic(5); matrix2 = magic(6); save matData.mat 用python3读取并写入 ...