http://acm.hdu.edu.cn/showproblem.php?pid=2851

首先有n层,每层的路径都有一个起点和终点和对应的危险值,如果某两层之间有交集,就能从这一层上到另外一层,不过只能上不能下.

给定m个目标点求出到目标点的最小危险值.

因为权值不一样,所以不能用bfs,dijkstra就好。

建图 就是把所有相连的边处理出来,因为读入是对y排序的.然后以此dijkstra就能求出所有点的最小花费。

 #include <cstdio>
#include <cstring>
#include <vector>
#include <queue>
using namespace std;
const int maxn = ;
const int INF = <<;
int n,m;
struct node
{
int x,y,cost;
}f[maxn]; struct edge
{
int to,cost;
edge(){}
edge(int x,int y) {
to=x;
cost=y;
}
};
typedef pair<int,int>P;
vector<edge>G[maxn];
int d[maxn];
void dijkstra(int s)
{
priority_queue<P,vector<P>,greater<P> >que;
for(int i=;i<=maxn;i++) d[i]=INF;
d[s]=f[].cost;
que.push(P(f[].cost,s)); while(!que.empty())
{
P p=que.top();que.pop();
int v=p.second;
if(d[v]<p.first) continue;
for(int i=;i<G[v].size();i++)
{
edge e=G[v][i];
if(d[e.to]>d[v]+e.cost)
{
d[e.to]=d[v]+e.cost;
que.push(P(d[e.to],e.to));
}
}
}
} int main()
{
//freopen("a.txt","r",stdin);
int t,k;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
{
G[i].clear();
scanf("%d%d%d",&f[i].x,&f[i].y,&f[i].cost);
}
//printf("%d\n",n);
for(int i=;i<=n;i++)
{
for(int j=i+;j<=n;j++)
if(f[j].x<=f[i].y)
{
G[i].push_back(edge(j,f[j].cost));
// printf("%d %d %d\n",i,j,p[i].cost+p[j].cost);
}
}
dijkstra();
for(int i=;i<m;i++)
{
scanf("%d",&k);
if(d[k]==INF) printf("-1\n");
else
printf("%d\n",d[k]);
}
}
return ;
}
05-26 05:07