Portal.
建一个虚拟节点 0 0 0 号节点(一种很常用的思路),把这个点与所有被僵尸占领的点都连一条边权为 1 1 1 的边,跑一遍从 0 0 0 开始的 Dijkstra,对于一个点如果得到的 dis 数组值小于等于 S + 1 S+1 S+1,那么就是危险城市。
然后跑一遍 Dijkstra,如果到达点为危险城市,边权为 Q Q Q;如果到达点为起点或终点,边权为 0 0 0;如果到达点为僵尸占领的点时,边权为 + ∞ +\infty +∞。
代码如下:
#include
using namespace std; #define int long long const int maxn=600005; int cnt,dis[maxn],a[maxn],b[maxn],head[maxn],nxt[maxn],to[maxn],w[maxn],N,M,K,S,c[maxn],P,Q; bool danger[maxn],vis[maxn]; void add(int x,int y,int z) { to[++cnt]=y; w[cnt]=z; nxt[cnt]=head[x]; head[x]=cnt; } struct node { int id,dis; friend bool operator < (node a,node b) { return a.dis>b.dis; } }; priority_queue q; void dij(int s) { memset(vis,0,sizeof(vis)); memset(dis,0x3f3f3f,sizeof(dis)); dis[s]=0;q.push(node{s,0}); while(!q.empty()) { int u=q.top().id;q.pop(); if(vis[u]) continue; vis[u]=1; for(int i=head[u];i;i=nxt[i]) if(dis[to[i]]>dis[u]+w[i]&&!vis[to[i]]) dis[to[i]]=dis[u]+w[i],q.push(node{to[i],dis[to[i]]}); } } signed main() { cin>>N>>M>>K>>S; cin>>P>>Q; for(int i=1;i<=K;i++) cin>>c[i],add(0,c[i],1),add(c[i],0,1); for(int i=1;i<=M;i++) cin>>a[i]>>b[i],add(a[i],b[i],1),add(b[i],a[i],1); dij(0); for(int i=1;i<=N;i++) if(dis[i]<=S+1) danger[i]=1; cnt=0; for(int i=1;i<=M;i++) head[i]=0,nxt[i]=0,w[i]=0,vis[i]=0; for(int i=1;i<=K;i++) vis[c[i]]=1; int tmp; for(int i=1;i<=M;i++) { if(vis[a[i]]||vis[b[i]]) continue; if(danger[b[i]]) tmp=Q; else tmp=P; add(a[i],b[i],tmp); if(danger[a[i]]) tmp=Q; else tmp=P; add(b[i],a[i],tmp); } dij(1); if(!danger[N]) cout<热门推荐信息
ByHashTang
现在已经有很多 ChatGPT 的套壳网站,以下分享验明 GPT-4 真身的三个经典问题,帮助你快速区分套壳网站背后到底用的是 GPT-3.5 还是 GPT-4。 大家可以在这个网站测试:https: ...
ByCyberSecurity_zhang
目录 1. 概述 2. 测量方式 -- Poll 3. 测量方式 -- DAQ 3.1 ODT概念模型 3.2 DAQ List概念 3.3 ODT 绝对编号和相对编号 3.4 静态DAQ和动态DAQ ...
Byqq_58647543
Dockerfile简介 从之前的学习中我们可以了解到:镜像的定制实际上就是定制每一层所添加的配置、文件。那么如果我们可以把每一层修改、安装、构建、操作的命令都写入一个脚本,用这个脚本来构建、定制镜像 ...
ByDontla
文章目录 Ubuntu下使用CuteCom进行串口调试使用指南什么是CuteCom?主要特点 安装CuteCom使用APT包管理器从源码编译安装 配置串口CuteCom界面解析(启动cutecom)使 ...
By新移科技
MediaTek联发科手机平台汇总: Qualcomm高通SOC平台汇总: 紫光展锐SOC平台汇总: 新移科技已成功研发手机SOC平台: 联发科平台: MTK6739、MTK6761、MTK6762、 ...