题目链接

毒瘤题

卡spfa

可能dij也卡,没试过

然后放floyd过了

但其实spfa很好打,虽然只有60

让我们来分析一下spfa的效率,假设这个出题人极其毒瘤,出网格图

又因为是在线询问,所以对于每次询问都得跑一次spfa

所以效率上界为$O(n*m*Q)$

代入一下最坏情况,$200*19900*50000=199000000000$

嗯,1.99*(10^11),成功炸飞

但是spfa特别好想也特别好打

在松弛的时候多判一下$if(t[u]>T||t[v]>T)continue$就好

其他都是标准spfa操作

题目中给的t是有序的,如果是无序的需要离线处理排序一下

Code(spfa):

#include <cstdio>
#include <cstring>
using namespace std;
#define N 80000
#define inf (1<<30)
int n,m,t[N];
int cnt,head[N];
int d[N],q[N];
bool vis[N];
struct edge{int to,next,v;}e[N<<];
void ins(int u,int v,int w){
e[++cnt].to=v;e[cnt].next=head[u];e[cnt].v=w;head[u]=cnt;
e[++cnt].to=u;e[cnt].next=head[v];e[cnt].v=w;head[v]=cnt;
}
bool spfa(int s,int ttt,int tt){
for(int i=;i<=n;i++)d[i]=inf;
memset(vis,,sizeof(vis));
int l=,r=;
d[s]=;q[]=s;vis[s]=;
while(l<r){
int u=q[l++];
for(int i=head[u];i;i=e[i].next){
int v=e[i].to;
if(t[u]>tt||t[v]>tt)continue;
if(d[v]>d[u]+e[i].v){
d[v]=d[u]+e[i].v;
if(!vis[v])vis[v]=,q[r++]=v;
}
}
vis[u]=;
}
if(d[ttt]==inf)return ;
return ;
}
int main(){
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)scanf("%d",&t[i]);
for(int i=;i<=m;i++){
int x,y,w;
scanf("%d%d%d",&x,&y,&w);
x++;y++;
ins(x,y,w);
}
int Q;
scanf("%d",&Q);
while(Q--){
int x,y,T;
scanf("%d%d%d",&x,&y,&T);
if(spfa(x+,y+,T))printf("%d\n",d[y+]);
else printf("-1\n");
}
return ;
}

好了接下来上正解

观察到t和每个询问里面的T是有序的

所以对于每个询问的T我们只要松弛已经修好的村庄就好了

然后如果出发点/终点还没修好那么肯定也没法到,特判一下

注意要建无向边

其实floyd比spfa还好打(雾)

Code(floyd):

#include <cstdio>
#include <cstring>
using namespace std;
#define inf 0x3f3f3f3f
int f[][],t[],n,m,k;
int min(int x,int y){return x<y?x:y;}
int main(){
scanf("%d%d",&n,&m);
memset(f,0x3f,sizeof(f));
for(int i=;i<n;i++)
scanf("%d",&t[i]),f[i][i]=;
for(int i=;i<m;i++){
int x,y,w;
scanf("%d%d%d",&x,&y,&w);
f[x][y]=f[y][x]=w;
}
int Q;
scanf("%d",&Q);
while(Q--){
int x,y,w;
scanf("%d%d%d",&x,&y,&w);
while(t[k]<=w&&k<=n){
for(int i=;i<n;i++)
for(int j=;j<n;j++)
f[i][j]=min(f[i][j],f[i][k]+f[k][j]);
k++;
}
if(f[x][y]==inf||t[x]>w||t[y]>w)printf("-1\n");
else printf("%d\n",f[x][y]);
}
return ;
}

[luoguP1119]灾后重建的更多相关文章

  1. [luoguP1119] 灾后重建(Floyd)

    传送门 基于Floyd的动态规划原理,我们可以只用进行一次Floyd. 而题目给出的限制条件相当于给Floyd加了时间限制而已. 还是得靠对Floyd的理解. ——代码 #include <cs ...

  2. CODEVS 1817 灾后重建 Label:Floyd || 最短瓶颈路

    描述 灾后重建(rebuild)  B地区在地震过后,所有村庄都造成了一定的损毁,而这场地震却没对公路造成什么影响.但是在村庄重建好之前,所有与未重建完成的村庄的公路均无法通车.换句话说,只有连接着两 ...

  3. AC日记——灾后重建 洛谷 P1119

    灾后重建 思路: 看到n<=200,思考弗洛伊德算法: 如何floyed呢? floyed是一种动态规划求最短路的算法: 它通过枚举中间点来更新两点之间最短路: 回到这个题本身: 所有点的重建完 ...

  4. 洛谷——P1119 灾后重建

    P1119 灾后重建 题目背景 B地区在地震过后,所有村庄都造成了一定的损毁,而这场地震却没对公路造成什么影响.但是在村庄重建好之前,所有与未重建完成的村庄的公路均无法通车.换句话说,只有连接着两个重 ...

  5. 【洛谷P1119题解】灾后重建——(floyd)

    这道题告诉我,背的掉板子并不能解决一切问题,理解思想才是关键,比如不看题解,我确实想不清楚这题是弗洛伊德求最短路 (我不该自不量力的说我会弗洛伊德了我错了做人果然要谦虚) 灾后重建 题目背景 B地区在 ...

  6. 洛谷 P1119 灾后重建 最短路+Floyd算法

    目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例 输出样例 说明 思路 AC代码 总结 题面 题目链接 P1119 灾后重建 题目描述 B地区在地震过后,所有村 ...

  7. java实现第六届蓝桥杯灾后重建

    灾后重建 题目描述 Pear市一共有N(<=50000)个居民点,居民点之间有M(<=200000)条双向道路相连.这些居民点两两之间都可以通过双向道路到达.这种情况一直持续到最近,一次严 ...

  8. [Luogu P1119] 灾后重建 (floyd)

    题面 传送门:https://www.luogu.org/problemnew/show/P1119 Solution 这题的思想很巧妙. 首先,我们可以考虑一下最暴力的做法,对每个时刻的所有点都求一 ...

  9. 【u110】灾后重建

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] B地区在地震过后,所有村庄都造成了一定的损毁,而这场地震却没对公路造成什么影响.但是在村庄重建好之前, ...

随机推荐

  1. oracle显示转换字段类型cast()函数

    今天遇到一个查询类型转换的问题:表的字段是varchar2类型,然后查询到的结果要转换为number(20,2),刚开始的时候使用to_number()函数,发现不能满足需求.后来才知道,原来还有ca ...

  2. dedecms手机站图片错误的解决方法

    现在手机站(如m.*.com)是网站建设标配,在用dedecms建站也可以实现(不会的话欢迎来骚扰ytkah),手机站一个比较麻烦的事是图片一直显示不出来,为什么呢?程序一般是调用图片的相对地址,比如 ...

  3. WordPress 3.8 后台仪表盘将重新设计

    WordPress 3.8 的后台仪表盘界面将会重新设计 概况(RightNow) -> 改为网站内容(SiteContent) 快速发布(QuickPress) -> 改为快速草稿(Qu ...

  4. Centos安装ELK5.3.2

    一.注意情况 1.elk的版本要一致. 2.ElasticSearch是基于lucence开发的,也就是运行需要java支持.所以要先安装JAVA环境.由于es5.x依赖于JDK1.8,所以需要安装J ...

  5. [LeetCode] 301. Remove Invalid Parentheses_Hard tag:BFS

    Remove the minimum number of invalid parentheses in order to make the input string valid. Return all ...

  6. Sublime text 3搭建Python-Anaconda开发环境

    网络上的教程各种各样,大同小异.自己安装时还是出了些问题,因此总结一篇博文. Sublime Text 是一款轻量级跨平台的文本编辑器,可通过包(Package)扩充自身功能. 有很多搭建python ...

  7. 浅谈Java中的==和equals

    引言 最近在看TIJ,看到==和equals相关内容,今天就来简单的总结下. 关系操作符== 书中对关系操作符的描述是这样的:"关系操作符生成的是一个boolean结果,它们计算的是操作数的 ...

  8. SpringBoot与Docker1

    1:docker是一个开源的应用容器引擎: docker支持将软件编译成一个镜像:然后再镜像中各种软件做好配置,将镜像发布出去,其他使用者可以直接使用这个镜像: 运行中的这个镜像称为容器,容器启动是非 ...

  9. #C++初学记录(深度搜索#递归)

    深度搜索 走地图的题目是深度搜索里比较容易理解的题目,更深层次的是全排列和七皇后等经典题目,更加难以理解,代码比较抽象. 题目:红与黑 蒜厂有一间长方形的房子,地上铺了红色.黑色两种颜色的正方形瓷砖. ...

  10. mysql的Navicat查看数据库的ER图

    1.mysql数据库表间的关系图可以通过navicat查看.