[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市计划新开设一条公交线路,该线路从城市的东站( ...
随机推荐
- windows系统安装jira
主题介绍 JIRA是Atlassian公司出品的项目与事务跟踪工具,被广泛应用于缺陷跟踪.客户服务.需求收集.流程审批.任务跟踪.项目跟踪和敏捷管理等工作领域,其配置灵活.功能全面.部署简单.扩展丰 ...
- 【RMAN】Oracle中如何备份控制文件?备份控制文件的方式有哪几种?
真题1. 如何备份控制文件?备份控制文件的方式有哪几种? 答案:备份控制文件的方式有多种. ① 备份控制文件可以在线进行: SQL> ALTER DATABASE BACKUP CONTROLF ...
- js制作列表滚动(有滚动条)
function mouseWheel(obj, fn){ var ff = navigator.userAgent.indexOf("Firefox"); if (ff != - ...
- PHP教程-防止网站被刷票的小技巧
在Web开发中,投票模块会经常出现.这样就使得防止刷票,成了至关重要的技术.以下是兄弟连教育www.itxdl.cn总结的一些防止刷票方法: 1. IP限制 这是使用的最多,也是最广泛,不可少的刷票限 ...
- python3把txt文件转换为csv文件
#!/usr/bin/python# -*- coding: UTF-8 -*-import csvwith open('file.csv','a',newline='') as csvfile: s ...
- 【Python】 压缩文件处理 zipfile & tarfile
[zipfile] 虽然叫zipfile,但是除了zip之外,rar,war,jar这些压缩(或者打包)文件格式也都可以处理. zipfile模块常用的一些操作和方法: is_zipfile(file ...
- linux --> 进程和线程
进程和线程 进程(process)和线程(thread)是操作系统的基本概念,下面用一个类比,来解释它们. 1. 计算机的核心是CPU,它承担了所有的计算任务.它就像一座工厂,时刻在运行. 2. 假定 ...
- 测试驱动开发实践3————testSave之新增用户
内容指引 1.确定新增用户的业务规则 2.根据业务规则设计测试用例 3.为测试用例赋值并驱动开发 一.确定新增用户的规则 1.注册用户允许通过"用户名+密码"."手机号+ ...
- 关于input内容改变的触发时间
1.onchange onchange 事件会在域的内容改变时触发.支持的标签<input type="text">, <textarea>, <se ...
- sphinx的安装
1.下载sphinx 没想到sphinx3解压后即可: wget http://sphinxsearch.com/files/sphinx-3.0.2-2592786-linux-amd64.tar. ...