Gym 101873C - Joyride - [最短路变形][优先队列优化Dijkstra]
题目链接:http://codeforces.com/gym/101873/problem/C
题意:
这是七月的又一个阳光灿烂的日子,你决定和你的小女儿一起度过快乐的一天。因为她真的很喜欢隔壁镇上的仙女公园,所以你决定到那儿去玩一天。
你妻子同意开车送你去公园接你。她非常准时,所以她确切地告诉你她什么时候会到公园的前门来接你,而你必须恰好在那个时间到那里。因为你显然也不想在外面等,这样会让你的小女儿伤心——她本可以在公园里多待些时间。
现在你必须考虑游玩计划。你知道你什么时候到达,什么时候离开。公园由若干游玩设施组成,两两之间由人行道相连。进入公园是免费的,但你每次使用在公园里的某项设施,都必须付一次相应费用。你已经知道玩每一项游玩设施各自需要多长时间、花多少钱。
当你穿过公园时,你显然不能在沿着公园走的时候跳过游乐设施(即使乔伊已经用了),否则乔伊会很伤心。因为乔非常喜欢公园,她很乐意玩同一个项目不止一次。在两个游乐项目之间行走需要一定的时间。
因为你是一个有计划的家长,所以当你在公园的时候,你要尽量少花钱。你能计算至少要花多少钱吗?
输入:
一行,一个整数 $x(1 \le x \le 1e3)$ 代表你们在公园玩的确切时间。
一行,三个整数 $n,m,t(1 \le n,m,t \le 1e3)$,代表有 $n$ 个娱乐设施, 之间有 $m$ 条人行道连接,走人行道需要花费 $t$ 分钟。
$m$ 行,每行 $a,b$ 代表设施 $a,b$ 之间有一条小路。
$n$ 行,每行 $t,p$ 代表该项游乐设施花费 $t$ 分钟,$p$ 元。
你从设施 $1$ 出发,最后必须回到设施 $1$。
Sample Input 1
4
4 4 1
1 2
2 3
3 4
4 1
1 2
2 1
5 4
3 3
Sample Output 1
8
Sample Input 2
6
4 4 1
1 2
2 3
3 4
4 1
1 2
2 1
5 4
3 3
Sample Output 2
5
题解:
按花费钱的数量跑最短路,$dist[v][k]$ 表示在 $k$ 时刻走到点 $v$ 最少花费 $dist[v][t]$ 元。
AC代码:
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e3+; int x;
int n,m,w;
int t[maxn],p[maxn]; struct Edge{
int u,v,w;
Edge(){}
Edge(int _u,int _v){u=_u, v=_v;}
};
vector<Edge> E;
vector<int> G[maxn];
void addedge(int u,int v)
{
E.push_back(Edge(u,v));
G[u].push_back(E.size()-);
} struct Qnode
{
int v,k,d;
Qnode(){}
Qnode(int _v,int _k,int _d) {
v=_v, k=_k, d=_d;
}
bool operator<(const Qnode& oth)const {
return d>oth.d;
}
};
int dist[maxn][maxn];
bool vis[maxn][maxn];
void dijkstra()
{
memset(dist,0x3f,sizeof(dist));
memset(vis,,sizeof(vis)); priority_queue<Qnode> Q;
if(t[]<=x) dist[][t[]]=p[];
else return;
Q.push(Qnode(,t[],p[]));
while(!Q.empty())
{
int u=Q.top().v, k=Q.top().k; Q.pop();
if(vis[u][k]) continue;
vis[u][k]=;
if(k+t[u]<=x && dist[u][k+t[u]]>dist[u][k]+p[u])
{
dist[u][k+t[u]]=dist[u][k]+p[u];
Q.push(Qnode(u,k+t[u],dist[u][k+t[u]]));
}
for(int i=;i<G[u].size();i++)
{
Edge &e=E[G[u][i]]; int v=e.v;
if(k+w+t[v]>x) continue;
if(!vis[v][k+w+t[v]] && dist[v][k+w+t[v]]>dist[u][k]+p[v])
{
dist[v][k+w+t[v]]=dist[u][k]+p[v];
Q.push(Qnode(v,k+w+t[v],dist[v][k+w+t[v]]));
}
}
}
} int main()
{
cin>>x>>n>>m>>w;
for(int i=,u,v;i<=m;i++)
{
cin>>u>>v;
addedge(u,v);
addedge(v,u);
}
for(int i=;i<=n;i++) cin>>t[i]>>p[i];
dijkstra();
if(vis[][x]) cout<<dist[][x]<<endl;
else cout<<"It is a trap."<<endl;
}
Gym 101873C - Joyride - [最短路变形][优先队列优化Dijkstra]的更多相关文章
- POJ 3635 - Full Tank? - [最短路变形][优先队列优化Dijkstra]
题目链接:http://poj.org/problem?id=3635 Description After going through the receipts from your car trip ...
- ZOJ - 3946-Highway Project(最短路变形+优先队列优化)
Edward, the emperor of the Marjar Empire, wants to build some bidirectional highways so that he can ...
- POJ 1511 Invitation Cards(单源最短路,优先队列优化的Dijkstra)
Invitation Cards Time Limit: 8000MS Memory Limit: 262144K Total Submissions: 16178 Accepted: 526 ...
- poj 1511 优先队列优化dijkstra *
题意:两遍最短路 链接:点我 注意结果用long long #include<cstdio> #include<iostream> #include<algorithm& ...
- hdu 1874(最短路 Dilkstra +优先队列优化+spfa)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- 最短路模板|堆优化Dijkstra,SPFA,floyd
Ⅰ:Dijkstra单源点最短路 1.1Dijkstra const int MAX_N = 10000; const int MAX_M = 100000; const int inf = 0x3f ...
- BZOJ 3040 最短路 (堆优化dijkstra)
这题不是裸的最短路么?但是一看数据范围就傻了.点数10^6,边数10^7.这个spfa就别想了(本来spfa就是相当不靠谱的玩意),看来是要用堆优化dijkstra了.但是,平时写dijkstra时为 ...
- POJ-1797Heavy Transportation,最短路变形,用dijkstra稍加修改就可以了;
Heavy Transportation Time Limit: 3000MS Memory Limit: 30000K Description Background Hugo ...
- 【BZOJ】BZOJ3040 最短路 线段树优化Dijkstra
题目描述 N个点,M条边的有向图,求点1到点N的最短路(保证存在). 1<=N<=1000000,1<=M<=10000000 输入格式 第一行两个整数N.M,表示点数和边数. ...
随机推荐
- 终止java线程的2种方法
1.使用一个volatile的共享变量 2.使用interrupt方法 import java.util.concurrent.TimeUnit; /** * ThreadTest */ public ...
- .NET内存泄漏(之 静态事件)
一.事件引起的内存泄露 1.不手动注销事件也不发生内存泄露的情况 我们经常会写EventHandler += AFunction; 如果没有手动注销这个Event handler类似:EventHan ...
- phpunit assert断言分类整理
布尔类型 方法名 含义 参数 返回值 assertTrue 断言为真 assertFalse 断言为假 NULL类型 方法名 含义 参数 返回值 assertNull 断言为NULL ...
- Spring-Cloud-Gateway 从升级到放弃
1 为什么要升级为spring-cloud-gateway? Spring Cloud Gateway features: Built on Spring Framework 5, Project R ...
- iOS开发小技巧 - UILabel添加中划线
iOS开发小技巧 遇到的问题: 给Label添加中划线,然后并没有效果 NSString *str = [NSString stringWithFormat:@"合计金额 ¥%.2f&quo ...
- java jdk 打开出错 Failed to load the JNI shared library
``` Failed to load the JNI shared library 解决方法 换了JDK 32位x86的 打开32位 eclipse 2017 oxygen 出现这个问题,修改 配置文 ...
- Docker-服务(4)
服务定义 在分布式应用程序中,应用程序的不同部分称为“服务”.例如,如果您想象一个视频共享站点,它可能包括一个用于在数据库中存储应用程序数据的服务,一个用户在上传内容后在后台进行视频转码的服务,一个用 ...
- jQuery UI =>jquery-ui.js中sortable方法拖拽对象位置偏移问题
今天要处理sortable方法处理的对象,拖拽的时候,位置偏移的问题. 按理应该是鼠标在哪,对象就跟着在哪的 百度了一下问题,http://blog.csdn.net/samed/article/de ...
- C#获取一个数组中的最大值、最小值、平均值
C#获取一个数组中的最大值.最小值.平均值 1.给出一个数组 ,,,,,-,,,,}; 2.数组Array自带方法 本身是直接可以调用Min(),Max(),Average()方法来求出 最小值.最大 ...
- Psi Probe 安装及使用说明
这是一款 Tomcat 管理和监控工具,前身是 Lambda Probe.由于 Lambda Probe 2006不再更新,所以 PSI Probe 算是对其的一个 Fork 版本并一直更新至今. g ...