Nowcoder contest 370B Rinne Loves Graph 【分层图最短路】
<题目链接>
题目大意:
现在他们想从 1 号城镇最快的走到 n 号城镇(即出口),现在他们想让你告诉他们最短需要走多少路。
2≤n≤800,1≤m≤4000,1≤k≤10,1≤w≤10^6
解题分析:
本题很明显是一道分成图最短路的题。主要的就是怎么处理"穿过"K个点,我是通过在最短路松弛过程中,判断下一个点是否是封锁点,是的话,就要利用分层图的性质进行松弛。因为题目规定的是穿过k个封锁点,所以我们需要对起点和终点进行处理。如果起点是封锁点,那么k--,如果终点是封锁点k++,因为起点是一定要穿过的,而终点穿不过。
#include <bits/stdc++.h>
using namespace std; #define clr(a,b) memset(a,b,sizeof(a))
#define rep(i,s,t) for(int i=s;i<=t;i++)
typedef long long ll;
const int N = , M = ;
int n,m,k,cnt;
int isgo[N],head[N]; template<typename T>
inline void read(T&x){
x=;int f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar(); }
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
x*=f;
}
struct Edge{
int to,nxt;ll w;
}edge[M<<]; struct Node{
int loc,lev;ll dist;
Node(int _loc=,int _lev=,ll _dist=):loc(_loc),lev(_lev),dist(_dist){}
bool operator < (const Node &tmp)const{ return dist>tmp.dist; }
}node[N][];
int vis[N][]; inline void init(){ cnt=;clr(head,-); }
inline void add(int u,int v,ll w){
edge[++cnt].to=v,edge[cnt].nxt=head[u];
edge[cnt].w=w;head[u]=cnt;
}
void Dij(){
rep(i,,n) rep(j,,k){
node[i][j].loc=i,node[i][j].lev=j;
node[i][j].dist=1e18;vis[i][j]=;
}
priority_queue<Node>q;
node[][].dist=;
q.push(node[][]);
while(!q.empty()){
Node now=q.top();q.pop();
int loc=now.loc,lev=now.lev;
if(vis[loc][lev])continue;
vis[loc][lev]=;
for(int i=head[loc];~i;i=edge[i].nxt){
int v=edge[i].to;ll cost=edge[i].w;
if(!isgo[v] && node[v][lev].dist>node[loc][lev].dist+cost){ //进行同层次建进行正常的松弛
node[v][lev].dist=node[loc][lev].dist+cost;
q.push(Node(v,lev,node[v][lev].dist));
}
if(isgo[v] && (lev+)<=k && node[v][lev+].dist>node[loc][lev].dist+cost){ //不是封锁点的就没有必要利用分层图进行松弛,因为在正常的一层就已经松弛了
node[v][lev+].dist=node[loc][lev].dist+cost;
q.push(Node(v,lev+,node[v][lev].dist));
}
}
}
}
int main(){
init();
read(n);read(m);read(k);
rep(i,,n) read(isgo[i]);
rep(i,,m){
int u,v;ll w;read(u);read(v);read(w);
add(u,v,w);add(v,u,w);
}
if(isgo[])k--;
if(isgo[n])k++;
Dij();
ll ans=1e18;rep(i,,k)ans=min(ans,node[n][i].dist);
printf("%lld\n",ans);
}
Nowcoder contest 370B Rinne Loves Graph 【分层图最短路】的更多相关文章
- Nowcoder contest 370H Rinne Loves Dynamic Graph【分层图最短路】
<题目链接> 题目大意:Rinne 学到了一个新的奇妙的东西叫做动态图,这里的动态图的定义是边权可以随着操作而变动的图.当我们在这个图上经过一条边的时候,这个图上所有边的边权都会发生变动. ...
- Nowcoder contest 370F Rinne Loves Edges (简单树形DP) || 【最大流】(模板)
<题目链接> 题目大意: 一个 $n$ 个节点 $m$ 条边的无向连通图,每条边有一个边权 $w_i$.现在她想玩一个游戏:选取一个 “重要点” S,然后选择性删除一些边,使得原图中所有除 ...
- poj3635Full Tank?[分层图最短路]
Full Tank? Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7248 Accepted: 2338 Descri ...
- HDU 5669 线段树优化建图+分层图最短路
用线段树维护建图,即把用线段树把每个区间都标号了,Tree1中子节点有到达父节点的单向边,Tree2中父节点有到达子节点的单向边. 每次将源插入Tree1,汇插入Tree2,中间用临时节点相连.那么T ...
- BZOJ 2763 分层图最短路
突然发现我不会分层图最短路,写一发. 就是同层中用双向边相连,用单向边连下一层 #include <cstdio> #include <algorithm> #include ...
- 【网络流24题】 No.15 汽车加油行驶问题 (分层图最短路i)
[题意] 问题描述:给定一个 N*N 的方形网格,设其左上角为起点◎, 坐标为( 1, 1), X 轴向右为正, Y轴向下为正, 每个方格边长为 1, 如图所示. 一辆汽车从起点◎出发驶向右下角终点▲ ...
- 【网络流24题】 No.14 孤岛营救问题 (分层图最短路)
[题意] 1944 年,特种兵麦克接到国防部的命令,要求立即赶赴太平洋上的一个孤岛, 营救被敌军俘虏的大兵瑞恩. 瑞恩被关押在一个迷宫里, 迷宫地形复杂, 但幸好麦克得到了迷宫的地形图. 迷宫的外形是 ...
- BZOJ_2662_[BeiJing wc2012]冻结_分层图最短路
BZOJ_2662_[BeiJing wc2012]冻结_分层图最短路 Description “我要成为魔法少女!” “那么,以灵魂为代价,你希望得到什么?” “我要将有关魔法和奇迹的一切, ...
- BZOJ_1579_[Usaco2009 Feb]Revamping Trails 道路升级_分层图最短路
BZOJ_1579_[Usaco2009 Feb]Revamping Trails 道路升级_分层图最短路 Description 每天,农夫John需要经过一些道路去检查牛棚N里面的牛. 农场上有M ...
随机推荐
- js——事件冒泡与捕获小例子
布局代码 #outer{ width: 300px; height: 300px; background: red; } #inner{ width: 200px; height: 200px; ba ...
- CSS3-字体渐变色
示例:Mauger`s Blog <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"& ...
- Confluence 6 订阅所应用的所有小工具
你可以从你的 Jira, Bamboo,FishEye 或 Crucible 站点中订阅所有的小工具到你的 Confluence 小工具目录中.用户可以为他们的页面查找和选择小工具. 希望订阅其他站点 ...
- Confluence 6 从外部目录中同步数据配置同步间隔
在用户目录(User Directories)界面中显示了最后的系统同步时间,包括有这次同步所花费的时间. 注意:针对 Crowd 和 Jira 目录同步时间的配置只在 Confluence 3.5 ...
- Django框架之第二篇
一.知识点回顾 1.MTV模型 model:模型,和数据库相关的 template:模板,存放html文件,模板语法(目的是将变量如何巧妙的嵌入到HTML页面中). views:视图函数 另加urls ...
- LeetCode(121):买卖股票的最佳时机
Easy! 题目描述: 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你所能获取的最大利润. 注意你不能在买 ...
- 【sqli-labs】Less18~Less22
Less18: User-Agent注入,有错误回显 感叹一句,越来越难了.现在只能先看代码再分析怎么注入了..... 通过代码,发现username和password均做了校验.但是会有一个插入us ...
- Eclipse中部署Android开发环境插件安装问题方案
1.添加第一个插件ADT之后出现eclipse原有的SDK管理问题.需要重新安装SDK 2.一种方式按照系统提示直接联网自动搜索安装,另一种就是下载好之后import. 1.用接口声明的变量称为接口变 ...
- bzoj 3129
非常好的一道数学题,考察了大量数论和组合数学的知识 在做本题之前强烈建议先完成下列两个背景知识: ①: bzoj 2142礼物 因为本题的一部分数据需要利用到拓展卢卡斯定理,而礼物是拓展卢卡斯定理的裸 ...
- MySQL源码安装一键脚本
#红色部分根据自己的需求来定义#!/bin/bash #卸载系统自带的Mysql /bin/rpm -e $(/bin/rpm -qa | grep mysql|xargs) --nodeps /bi ...