ACM-ICPC 2018 南京赛区网络预赛 L 【分层图最短路】
<题目链接>
题目大意:
有N个城市,这些城市之间有M条有向边,每条边有权值,能够选择K条边 边权置为0,求1到N的最短距离。
解题分析:
分层图最短路模板题,将该图看成 K+1 层图,然后具体解析见代码:
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #include <queue> using namespace std; #define INF 0x7ffffffffff; ; ; typedef long long ll; int n,m,k,tot,cnt; int head[M]; ]; struct EDGE{ int to; int next; ll val; }edge[M<<]; struct NODE{ int loc,cal; //loc代表该点的标号,cal代表该点所在的层数,这两个变量可以确定分层图中所有点的位置 ll dist; bool operator <(const NODE &tmp)const{ return dist>tmp.dist; } NODE(,,ll w=){ loc=a,cal=b,dist=w; } }d[N][]; void init(){ cnt=; memset(head,-,sizeof(head)); } void add(int u,int v,int w){ edge[++cnt].to=v,edge[cnt].val=w; edge[cnt].next=head[u],head[u]=cnt; } void dij(){ memset(vis,false,sizeof(vis)); ;i<=n;i++){ ;j<=k;j++){ d[i][j].dist=INF; //将所有点到起点的距离初始化为无穷大 } } d[][].dist=; priority_queue<NODE>q; q.push(NODE(,,d[][].dist)); while(!q.empty()){ NODE now=q.top(); q.pop(); int tmp1=now.loc,tmp2=now.cal; if(vis[tmp1][tmp2])continue; vis[tmp1][tmp2]=true; for(int i=head[tmp1];~i;i=edge[i].next){ int v=edge[i].to; ll cost=edge[i].val; if(d[v][tmp2].dist>d[tmp1][tmp2].dist+cost){ //在同一层中进行普通的松弛操作,表示当前道路的权值不用置为0 d[v][tmp2].dist=d[tmp1][tmp2].dist+cost; q.push(NODE(v,tmp2,d[v][tmp2].dist)); } <=k&&d[v][tmp2+].dist>d[tmp1][tmp2].dist){ //没有加上cost,代表 tmp1-->v 这段路的权值置为0 d[v][tmp2+].dist=d[tmp1][tmp2].dist; q.push(NODE(v,tmp2+,d[v][tmp2+].dist)); } } } } int main(){ int T;scanf("%d",&T); while(T--){ init(); scanf("%d%d%d",&n,&m,&k); ;i<=m;i++){ int u,v;ll w; scanf("%d%d%lld",&u,&v,&w); add(u,v,w); } dij(); ll mn=INF; ;i<=k;i++){ //在所有层中选取最短的情况 mn=min(mn,d[n][i].dist); } printf("%lld\n",mn); } ; }
2018-09-12
ACM-ICPC 2018 南京赛区网络预赛 L 【分层图最短路】的更多相关文章
- ACM-ICPC 2018 南京赛区网络预赛 L. Magical Girl Haze
262144K There are NN cities in the country, and MM directional roads from uu to v(1\le u, v\le n)v ...
- ACM-ICPC 2018 南京赛区网络预赛 L题(分层最短路)
题目链接:https://nanti.jisuanke.com/t/31001 题目大意:给出一个含有n个点m条边的带权有向图,求1号顶点到n号顶点的最短路,可以使<=k条任意边的权值变为0. ...
- ACM-ICPC 2018 南京赛区网络预赛 L题(分层图,堆优化)
题目链接: https://nanti.jisuanke.com/t/31001 超时代码: #include<bits/stdc++.h> using namespace std; # ...
- ACM-ICPC 2018 南京赛区网络预赛 L.Magical Girl Haze(分层最短路)
There are N cities in the country, and M directional roads from u to v(1≤u,v≤n). Every road has a di ...
- ACM-ICPC 2018 南京赛区网络预赛 L. Magical Girl Haze 最短路+分层图
类似题解 There are NN cities in the country, and MM directional roads from uu to v(1\le u, v\le n)v(1≤u, ...
- ACM-ICPC 2018 南京赛区网络预赛 - L Magical Girl Haze (分层迪杰斯特拉)
题意:N个点,M条带权有向边,求可以免费K条边权值的情况下,从点1到点N的最短路. 分析:K<=10,用dist[i][j]表示从源点出发到点i,免费j条边的最小花费.在迪杰斯特拉的dfs过程中 ...
- ACM-ICPC 2018 南京赛区网络预赛 L && BZOJ 2763 分层最短路
https://nanti.jisuanke.com/t/31001 题意 可以把k条边的权值变为0,求s到t的最短路 解析 分层最短路 我们建立k+1层图 层与层之间边权为0,i 向 i+1层转 ...
- 【ACM-ICPC 2018 南京赛区网络预赛 L】Magical Girl Haze
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 定义dis[i][j]表示到达i这个点. 用掉了j次去除边的机会的最短路. dis[1][0]= 0; 在写松弛条件的时候. 如果用 ...
- ACM-ICPC 2018 南京赛区网络预赛 L. Magical Girl Haze (分层dijkstra)
There are NN cities in the country, and MMdirectional roads from uu to v(1\le u, v\le n)v(1≤u,v≤n). ...
随机推荐
- chkconfig: command not found
问题描述 Ubuntu 16.04 下安装 Nginx 服务器,在添加 nginx 服务时出现如下信息 # chkconfig --add nginx chkconfig: command not f ...
- LoadRunner学习笔记
什么是性能测试: 简单说,功能测试是软件是否能用,性能测试是看软件好不好用: 性能测试的含义,大体来讲就是通过自动化的手段,模拟生产运行的业务压力或者相应的场景,来测试协同系统是否满足生产需要. 性能 ...
- 使用 Kafka 和 Spark Streaming 构建实时数据处理系统
使用 Kafka 和 Spark Streaming 构建实时数据处理系统 来源:https://www.ibm.com/developerworks,这篇文章转载自微信里文章,正好解决了我项目中的技 ...
- SpringMVC类型转换,验证
点击上一章-SpringMVC视图及REST风格 Spring mvc 数据绑定流程: SpringMvc将ServletRequest对象及目标方法的形参实例传给WebDataBinderFacto ...
- django之ORM数据库操作
一.ORM介绍 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录----------------->类实例 ...
- Dig skipfish proxystrike
1.DNS域名信息收集,(Dig,挖掘局域网的信息之前的博客中已经做过介绍) 查询需要认证的域名服务器 dig -t ns + 网址 使用工具 fierce 判断主机上存活的其他域名服务器 ...
- 使用Calendar获取上一月,下一月,上一年,下一年的当天日期
Calendar的add(int field,int amount)方法 field 表示月或年,天等字段 amount 代表增量或减量 例如: 上月的当天日期 Calendar cal = Cal ...
- MyBatis - 2.全局文件配置
1.properties 属性 <!--properties 引入外部配置文件 properties 的内容 resource: 引入类路径资源 url: 引入网络资源 --> <p ...
- webpack学习笔记--配置plugins
Plugin Plugin 用于扩展 Webpack 功能,各种各样的 Plugin 几乎让 Webpack 可以做任何构建相关的事情. 配置 Plugin Plugin 的配置很简单, plugi ...
- 解决h5网页微信分享链接不能显示缩略
<script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js& ...