HDU4725

题目大意:一些节点分布在不同的层上,已知相邻的层可以往来距离为c,在给你一些已知的边,问你点1-n的最短路

分析:越往后做,越觉得最短路的考点已经不是spfa算法还是dijkscar算法了,而是图形的创建,你脑海里既要有他给你描绘出的问题场景图,也要有适应算法而建造的图模型,其实这个题有很多的建图方式,看你怎么想了,只能说我的模型化思想还没有完全好,这个图在我脑子里已经TLE了,看了看别人的题目大意又重整旗鼓模拟了一下~~

就是你把一个层就看做一个点,一开始的输入会告诉你每一个点具体在第几层,你可以标记一下,哪些层出现过(TLE点1:你当然可以不标记,然后给每一个相邻的层建边,但是spfa就会麻烦了,tle,因为很可能你会在没有点的层上乱逛)

for(int i = 1;i <= n;i++)
{
scanf("%d",&flor[i]);//i点在l层
vis[flor[i]] = 1;
}
for(int i = 1;i < n;i++)
{
if(vis[i] && vis[i + 1])
{
add(i + n,i + n + 1,c);
add(i + n + 1,i + n,c);
}
}

层层间的路建好了,就剩下点和层的了,(TLE点2:一般都会想的是,把点和它所在的层一一连接起来就好了也就是i 和 n + flor[i]),其实这是一条比较费的路,只会徒增加时间,要知道spfa的队列限制了它一步一步更新最短路,所以你的结点越多,也就会越慢,所以直接跨越一个结点,连接i和i层所在的上下层

剩下的就真的是默写spfa了

#include <iostream>
#include <queue>
#include <cstdio>
#include <string.h>
#include <vector>
#define inf 0x3f3f3f3f
using namespace std;
const int maxn = 3e5 + 3e2; struct node
{
int to,cost,pre;
// node(int t,int c,int p):to(t),cost(c),pre(p){}
}edge[maxn * 10];
//vector<node> edge[maxn];
int n;
int d[maxn];
int vis[maxn];
int id[maxn];
int cnt;int flor[maxn];
queue<int>q;
void init()
{
// memset(vis,0,sizeof(vis));
// memset(id,-1,sizeof(id));
for(int i = 1;i <= 3*n;i++)
{
// edge[i].clear();
d[i] = inf;
vis[i] = 0;
id[i] = -1;
}
memset(flor,0,sizeof(flor));
cnt = 0;
while(!q.empty())q.pop();
}
void add(int from,int to,int cost)
{
// edge[from].push_back(node(to,cost));
edge[cnt].to = to;
edge[cnt].cost = cost;
edge[cnt].pre = id[from];
id[from] = cnt++;
}
void spfa(int s)
{
memset(vis,0,sizeof(vis));
d[s] = 0;
vis[s] = 1;
q.push(s);
while(q.size())
{
int now = q.front();q.pop();vis[now] = 0;
// for(int i = 0;i < edge[now].size();i++)
for(int i = id[now];~i;i = edge[i].pre)
{
// cout<<i<<endl;
// int to = edge[now][i].to;
// int cost = edge[now][i].cost;
int to = edge[i].to;
int cost = edge[i].cost;
if(d[to] > d[now] + cost)
{
d[to] = d[now] + cost;
if(!vis[to])
{
vis[to] = 1;
q.push(to);
}
}
}
}
} int main()
{
int t,m,c,a,b,x;
scanf("%d",&t);
int cas = 1;
while(t--)
{
scanf("%d%d%d",&n,&m,&c);
init();
for(int i = 1;i <= n;i++)
{
scanf("%d",&flor[i]);//i点在l层
vis[flor[i]] = 1;
}
for(int i = 1;i < n;i++)
{
if(vis[i] && vis[i + 1])
{
add(i + n,i + n + 1,c);
add(i + n + 1,i + n,c);
}
}
for(int i = 1;i <= n;i++)
{
add(n + flor[i],i,0);
if(flor[i] > 1)
add(i,n + flor[i] - 1,c);
if(flor[i] < n)
add(i,n + flor[i] + 1,c);
}
while(m--)
{
scanf("%d%d%d",&a,&b,&x);
add(a,b,x);
add(b,a,x);
}
spfa(1);
if(d[n] == inf)d[n] = -1;
printf("Case #%d: %d\n",cas++,d[n]);
}
return 0;
}

WA了11次!思路很重要~!

【spfa训练】HDU4725 (层级建图)的更多相关文章

  1. 【建图+最短路】Bzoj1001 狼抓兔子

    Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个 ...

  2. UESTC30-最短路-Floyd最短路、spfa+链式前向星建图

    最短路 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) 在每年的校赛里,所有进入决赛的同 ...

  3. The Shortest Path in Nya Graph---hdu4725(spfa+扩点建图)

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=4725  有n个点,每个点都有一个层l[i],相邻层的边有一条无向带权边,权值为都为C,另外 ...

  4. Invitation Cards(邻接表+逆向建图+SPFA)

    Time Limit: 8000MS   Memory Limit: 262144K Total Submissions: 17538   Accepted: 5721 Description In ...

  5. HDU-4725.TheShortestPathinNyaGraph(最短路 + 建图)

    本题思路:主要是建图比较麻烦,因为结点可以在层与层之间走动,也可以在边上进行走动,所以主要就是需要找到一个将结点和层统一化处理的方法. 所以我们就可以对于存在边的结点建边,层与层之间如果层数相差一也建 ...

  6. POJ 1384 Intervals (区间差分约束,根据不等式建图,然后跑spfa)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1384 Intervals Time Limit: 10000/5000 MS (Java/Others ...

  7. HDU 4370 0 or 1(spfa+思维建图+计算最小环)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4370 题目大意:有一个n*n的矩阵Cij(1<=i,j<=n),要找到矩阵Xij(i< ...

  8. HDU 4725 The Shortest Path in Nya Graph(spfa+虚拟点建图)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4725 题目大意:有n层,n个点分布在这些层上,相邻层的点是可以联通的且距离为c,还有额外给出了m个条边 ...

  9. NOIP2013 华容道 (棋盘建图+spfa最短路)

    #include <cstdio> #include <algorithm> #include <cstring> #include <queue> # ...

随机推荐

  1. c#栈的习题2

    —.单项选择题1.栈和队列具有相同的(    ). A.抽象数据类型     B.逻辑结构     C.存储结构     D.运算2.栈是(). A.顺序存储的线性结构     B.链式存储的非线性结 ...

  2. js中常用的内部函数的使用

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  3. swift - 代码创建 pickerView 显示或隐藏横线

    import UIKit class VC1: UIViewController { fileprivate lazy var pickerV : UIPickerView = { let v = U ...

  4. centos7 二进制安装包安装 mysql5.6

    centos7 二进制安装包安装 mysql5.6 一.下载mysql5.6二进制安装包 http://mirrors.sohu.com/mysql/MySQL-5.6/ 如:mysql-5.6.34 ...

  5. cvc-complex-type.2.4.a: Invalid content was found starting with element 'init-param'.

    笔者最近学习一些spring mvc,在复制别人代码的时候报这个错.报错来源web.xml,原因是不符合xsd对xml的约束 源文件 <?xml version="1.0" ...

  6. linux新安装JDK不生效的问题

    新安装了jdk,但重新连接之后仍然显示老的jdk 1. which java 2. which javac 3. rm -rf /usr/bin/java 4. rm -rf /usr/bin/jav ...

  7. DirectFB编程

    一.简介 DirectFB是一个轻量级的提供硬件图形加速,输入设备处理和抽象的图形库,它集成了支持半透明的视窗系统以及在LinuxFramebuffer驱动之上的多层显示.它是一个用软件封装当前硬件无 ...

  8. binlog怎样参与mysql recover的

    转自  Louis Hust's Blog MySQL两阶段提交 29 July 2015 参数介绍 两阶段提交 什么情况下会出现binlog写入了,但是实际这条数据不存在库中? 参数介绍 innod ...

  9. 761A Dasha and Stairs

    A. Dasha and Stairs time limit per test 2 seconds memory limit per test 256 megabytes input standard ...

  10. 七大排序的个人总结(二) 归并排序(Merge

    七大排序的个人总结(二)   归并排序(Merge  归并排序(Merge Sort): 归并排序是一个相当“稳定”的算法对于其它排序算法,比如希尔排序,快速排序和堆排序而言,这些算法有所谓的最好与最 ...