[Luogu1342] 请柬 - 最短路模板
Description
在电视时代,没有多少人观看戏剧表演。Malidinesia古董喜剧演员意识到这一事实,他们想宣传剧院,尤其是古色古香的喜剧片。他们已经打印请帖和所有必要的信息和计划。许多学生被雇来分发这些请柬。每个学生志愿者被指定一个确切的公共汽车站,他或她将留在那里一整天,邀请人们参与。
这里的公交系统是非常特殊的:所有的线路都是单向的,连接两个站点。公共汽车离开起始点,到达目的地之后又空车返回起始点。学生每天早上从总部出发,乘公交车到一个预定的站点邀请乘客。每个站点都被安排了一名学生。在一天结束的时候,所有的学生都回到总部。现在需要知道的是,学生所需的公交费用的总和最小是多少。
Input&Output
Input
第1行有两个整数n、m(1<=n,m<=1000000),n是站点的个数,m是线路的个数。
然后有m行,每行描述一个线路,包括3个整数,起始点,目的地和价格。
总部在第1个站点,价钱都是整数,且小于1000000000。
Output
输出一行,表示最小费用。
Sample
Input
4 6
1 2 10
2 1 60
1 3 20
3 4 10
2 4 5
4 1 50
Output
210
Solution
本题是一道裸的最短路。需要特殊处理的问题在于,由于路线都是单向的,我们在求返程最短路时需要建一张反图。不得不说数据范围比较毒瘤,堆优化dijkstra可以稳定在O(nlogn),相较于O(玄学)的SPFA还是稳一些,另外建议读入优化。
代码如下:
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<queue>
#include<cctype>
#include<cstring>
#define maxn 1000005
#define INF_ 214748000000
using namespace std;
typedef unsigned long long ull;
struct edge{
int to,nxt,v;
}e[maxn],re[maxn];
int n,m,edgenum,redgenum,lnk[maxn],rlnk[maxn],u,v,w;
void add(int bgn,int end,int val)
{
e[++edgenum].to=end;
e[edgenum].v=val;
e[edgenum].nxt=lnk[bgn];
lnk[bgn]=edgenum;
}
void radd(int bgn,int end,int val)
{
re[++redgenum].to=end;
re[redgenum].v=val;
re[redgenum].nxt=rlnk[bgn];
rlnk[bgn]=redgenum;
}
inline int rd()
{
int x=0;char c=getchar();
while(!isdigit(c))c=getchar();
while(isdigit(c))x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x;
}
struct node{
ull dis;
int id;
node(ull d,int i):dis(d),id(i){}
bool operator < (const node &b)const{
return dis>b.dis;
}
};
ull dis[maxn];
bool vis[maxn];
void dij()
{
for(int i=1;i<=n;++i)
dis[i]=INF_;
priority_queue<node> q;
dis[1]=0;
q.push(node(0,1));
while(!q.empty()){
node u=q.top();q.pop();
if(vis[u.id])continue;
vis[u.id]=true;
for(int p=lnk[u.id];p;p=e[p].nxt){
int y=e[p].to;
if(dis[y]>dis[u.id]+e[p].v){
dis[y]=dis[u.id]+e[p].v;
q.push(node(dis[y],y));
}
}
}
}
void rdij()
{
for(int i=1;i<=n;++i)
dis[i]=INF_;
memset(vis,0,n+1);
priority_queue<node> q;
dis[1]=0;
q.push(node(0,1));
while(!q.empty()){
node u=q.top();q.pop();
if(vis[u.id])continue;
vis[u.id]=true;
for(int p=rlnk[u.id];p;p=re[p].nxt){
int y=re[p].to;
if(dis[y]>dis[u.id]+re[p].v){
dis[y]=dis[u.id]+re[p].v;
q.push(node(dis[y],y));
}
}
}
}
int main()
{
n=rd();m=rd();
for(int i=1;i<=m;++i)
u=rd(),v=rd(),w=rd(),add(u,v,w),radd(v,u,w);
dij();
ull sum=0;
for(int i=2;i<=n;++i)
sum+=dis[i];
rdij();
for(int i=2;i<=n;++i)
sum+=dis[i];
printf("%lld\n",sum);
return 0;
}
[Luogu1342] 请柬 - 最短路模板的更多相关文章
- POJ 2449Remmarguts' Date K短路模板 SPFA+A*
K短路模板,A*+SPFA求K短路.A*中h的求法为在反图中做SPFA,求出到T点的最短路,极为估价函数h(这里不再是估价,而是准确值),然后跑A*,从S点开始(此时为最短路),然后把与S点能达到的点 ...
- poj1511/zoj2008 Invitation Cards(最短路模板题)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud Invitation Cards Time Limit: 5 Seconds ...
- k短路模板 POJ2449
采用A*算法的k短路模板 #include <iostream> #include <cstdio> #include <cstring> #include < ...
- HDU 5521.Meeting 最短路模板题
Meeting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- ACM-ICPC 2018 沈阳赛区网络预赛 D. Made In Heaven(第k短路模板)
求第k短路模板 先逆向求每个点到终点的距离,再用dij算法,不会超时(虽然还没搞明白为啥... #include<iostream> #include<cstdio> #inc ...
- [poj2449]Remmarguts' Date(K短路模板题,A*算法)
解题关键:k短路模板题,A*算法解决. #include<cstdio> #include<cstring> #include<algorithm> #includ ...
- 51nod_1445 变色DNA 最短路模板 奇妙思维
这是一道最短路模板题,但是在理解题意和提出模型的阶段比较考验思维,很容易想到并且深深进入暴力拆解题目的无底洞当中. 题意是说:给出一个邻接矩阵,在每个点时,走且仅走向,合法路径中编号最小的点.问题是是 ...
- poj 2499第K短路模板
第k*短路模板(单项边) #include <iostream> #include <cstdio> #include <algorithm> #include & ...
- 牛客小白月赛6 I 公交线路 最短路 模板题
链接:https://www.nowcoder.com/acm/contest/136/I来源:牛客网 题目描述 P市有n个公交站,之间连接着m条道路.P市计划新开设一条公交线路,该线路从城市的东站( ...
随机推荐
- Readiness 探测 - 每天5分钟玩转 Docker 容器技术(144)
除了 Liveness 探测,Kubernetes Health Check 机制还包括 Readiness 探测. 用户通过 Liveness 探测可以告诉 Kubernetes 什么时候通过重启容 ...
- 使用angular-ui-router替代ng-router
angular框架自身提供的ng-route在一定程度上满足了我们的需求,但是他只针对于单视图,比如点击一个link跳转到另一个视图,但是在实际业务中,需要一个状态对应的视图中还包含其他的视图,或者一 ...
- http.request的请求
var http=require('http'); var request=require('request'); var body = { "data":{ "id&q ...
- Javscript的函数链式调用基础篇
我们都很熟悉jQuery了,只能jQuery中一种非常牛逼的写法叫链式操作: $('#div').css('background','#ccc').removeClass('box').stop(). ...
- vue技术解析六之生命周期函数
- MYSQL数据库学习十六 安全性机制
16.1 MYSQL数据库所提供的权限 16.1.1 系统表 mysql.user 1. 用户字段 Host:主机名: User:用户名: Password:密码. 2. 权限字段 以“_priv”字 ...
- php 常用数据大全
一.数组操作的基本函数 数组的键名和值 array_values($arr);获得数组的值 array_keys($arr);获得数组的键名 array_flip($arr);数组中的值与键名互换(如 ...
- 通过cmd命令行连接mysql数据库
找到 mysqld.exe所在的路径 使用cd切换到msyqld.exe路径下 输入mysql连接命令,格式如下 Mysql -P 端口号 -h mysql主机名\ip -u root (用户) ...
- 软件工程网络15团队作业1——团队组队&展示
Deadline: 2018-3-25 10:00PM,以提交至班级博客时间为准. 申请开通团队博客,并将团队博客地址发表在本次随笔的评论中 团队展示 根据5-6人的组队要求,每个队伍创建团队博客并发 ...
- backpropagation
github: https://github.com/mattm/simple-neural-network blog: https://mattmazur.com/2015/03/17/a-step ...