第十五届四川省省赛 SCU - 4444 Travel
给你一个一共由两种边的完全图 要求你求1到N的最短路
q队列为前沿队列(已探索过且最外围的点) p队列为未探索队列(未探索过的点)
depth这个数组的用法并不是代表实际上这个点在第几层 而是防止死循环 保证每次通过前沿的一个点都只会遍历p中每个点一次
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const long long mod = 1e9+;
const int maxn = 5e5+;
const int inf = 1e9+;
int n,m,a,b,nm,qwq;
int head[maxn];
ll dis[maxn];
struct node{
int to,nxt;
}edg[maxn*];
void add(int x,int y){
edg[++nm].to = y;
edg[nm].nxt = head[x];
head[x]=nm;
if(x==&&y==n)qwq=;
}
queue<int> p,q;
int f[maxn],dep[maxn];
void solve(){
dis[]=;
int i,j,x,y;
p.push();
for(i=;i<=n;i++){
q.push(i);
}
for(i=;i<=n;i++){
f[i]=;dep[i]=;
}
while(!p.empty()){
if(q.empty())break;
x = p.front();
p.pop();
for(i=head[x];i;i=edg[i].nxt)f[edg[i].to]=x;
j = dep[q.front()];
while(!q.empty()){
y = q.front();
if(dep[y]!=j)break;
q.pop();
dep[y]=dep[y]+;
if(f[y]==x)q.push(y);
else{
p.push(y);
dis[y]=dis[x]+b;
}
}
}
while(!p.empty())p.pop();
while(!q.empty())q.pop();
if(dis[n]==-||dis[n]>a)printf("%d\n",a);
else printf("%lld\n",dis[n]);
} void dist(){
int i,j,x,y;
dis[]=;
p.push();
while(!p.empty()){
x = p.front();
p.pop();
for(i=head[x];i;i=edg[i].nxt){
y = edg[i].to;
if(dis[y]!=-)continue;
dis[y]=dis[x]+a;
p.push(y);
}
}
if(dis[n]==-||dis[n]>b)printf("%d\n",b);
else printf("%lld\n",dis[n]);
}
int main()
{
while(scanf("%d%d%d%d",&n,&m,&a,&b)==){
qwq=;
nm = ;
int i,j,x,y;
for(i=;i<=n;i++){
head[i]=;
dis[i]=-;
}
for(i=;i<=m;i++){
scanf("%d%d",&x,&y);
add(x,y);
add(y,x);
}
if(a>=b){
if(qwq==){
printf("%d\n",b);
}
else solve();
}
else{
if(qwq==){
printf("%d\n",a);
}
else dist();
}
}
}
第十五届四川省省赛 SCU - 4444 Travel的更多相关文章
- 第十五届四川省省赛 SCU - 4443 Range Query
先给你1~N的N个数 再给你每种最多50个的条件(ai,bi,ci) 或者[ai,bi,ci] (ai,bi,ci)表示下标ai到bi的最小值必为ci [ai,bi,ci]表示下标ai到bi的最大值必 ...
- 第十五届四川省省赛 SCU - 4439 Vertex Cover
给你一个一般图 保证每条边的一端下标不大于30 问最小覆盖集的大小为多少 爆搜:枚举前30个点是否在覆盖集内 剪枝1:如果不在的话 那么他所连的下标大于30的点都必须选 剪纸2:最优解剪枝 #incl ...
- Minieye杯第十五届华中科技大学程序设计邀请赛现场同步赛 I Matrix Again
Minieye杯第十五届华中科技大学程序设计邀请赛现场同步赛 I Matrix Again https://ac.nowcoder.com/acm/contest/700/I 时间限制:C/C++ 1 ...
- 北京师范大学第十五届ACM决赛-重现赛 B Borrow Classroom (树 ——LCA )
链接:https://ac.nowcoder.com/acm/contest/3/B 来源:牛客网 Borrow Classroom 时间限制:C/C++ 3秒,其他语言6秒 空间限制:C/C++ 2 ...
- Minieye杯第十五届华中科技大学程序设计邀请赛网络赛D Grid(简单构造)
链接:https://ac.nowcoder.com/acm/contest/560/D来源:牛客网 题目描述 Give you a rectangular gird which is h cells ...
- H-Modify Minieye杯第十五届华中科技大学程序设计邀请赛现场赛
题面见 https://ac.nowcoder.com/acm/contest/700#question 题目大意是有n个单词,有k条替换规则(单向替换),每个单词会有一个元音度(单词里元音的个数)和 ...
- Minieye杯第十五届华中科技大学程序设计邀请赛网络赛 部分题目
链接:https://pan.baidu.com/s/12gSzPHEgSNbT5Dl2QqDNpA 提取码:fw39 复制这段内容后打开百度网盘手机App,操作更方便哦 D Grid #inc ...
- 福州大学第十五届程序设计竞赛_重现赛B题迷宫寻宝
Problem B 迷宫寻宝 Accept: 52 Submit: 183Time Limit: 1000 mSec Memory Limit : 32768 KB Problem De ...
- 第十五届浙江省赛 F Now Loading!!!
Now Loading!!! Time Limit: 1 Second Memory Limit: 131072 KB DreamGrid has integers . DreamGrid ...
随机推荐
- 自动化运维:(3)写一个简单的Shell脚本(案例)
一.需求 1.test.sh 脚本执行时候需要添加参数才能执行 参数和功能详情如下: 参数 执行效果 start 启动中... stop 关闭中... restart 重启中... * 脚本帮助信息. ...
- DRF视图-5个扩展类以及GenericAPIView基类
视图 5个视图扩展类 视图拓展类的作用: 提供了几种后端视图(对数据资源进行曾删改查)处理流程的实现,如果需要编写的视图属于这五种,则视图可以通过继承相应的扩展类来复用代码,减少自己编写的代码量. 这 ...
- vue-router跳转相同路径报错
import Vue from 'vue' import Router from 'vue-router' // hack router push callback const originalPus ...
- 论文阅读及复现 | Effective Neural Solution for Multi-Criteria Word Segmentation
主要思想 这篇文章主要是利用多个标准进行中文分词,和之前复旦的那篇文章比,它的方法更简洁,不需要复杂的结构,但比之前的方法更有效. 方法 堆叠的LSTM,最上层是CRF. 最底层是字符集的Bi-LST ...
- 【Python】【demo实验15】【练习实例】【两个数范围内素数的统计】
原题: 判断101-200之间有多少个素数,并输出所有素数. 关于素数的统计,之前已经做过相应的实验了,参考:[显示素数,显示两个数范围内的所有素数] 原题给出的解法,使用math的sqrt函数,这个 ...
- ubuntu 设置静态ip,但显示scope global secondary ens33
设置静态ip 修改 /etc/network/interfaces 文件 # The loopback network interface auto lo iface lo inet loopback ...
- windows下将多个文件合并成一个文件,将ts文件变成MP3格式
①:先把全部的ts文件下载下来放到指定文件夹,这里我是放在桌面的ls里 ②:从cmd进去找到桌面的路径,也可以像我这样直接在桌面的路径上敲cmd进入: ③:直接合并使用命令“copy /b ls\*. ...
- FFmpeg4.0笔记:封装ffmpeg的解封装功能类CDemux
Github https://github.com/gongluck/FFmpeg4.0-study/tree/master/Cff CDemux.h /*********************** ...
- Linux的一个后门引发对PAM的探究
转自http://www.91ri.org/16803.html 1.1 起因 今天在搜索关于Linux下的后门姿势时,发现一条命令如下:软链接后门: 1 ln -sf /usr/sbin/ssh ...
- flask 接收参数小坑
前后端分离: 1.get方式: items = dict(request.args.items()) app_name = items["app_name"].strip() 或 ...