CSU-1989 赶路的小X
题目链接
http://acm.csu.edu.cn:20080/csuoj/problemset/problem?pid=1989
题目
Description
A国一共有N座城市,由M条双向公路连接。小X现在位于S市,他正在赶往T市。小X的时间有限,他还剩下L的时间。另外,到达每座城市,小X都需要缴纳一定的过路费,包括S市和T市。在缴纳过路费时,单次的花费越多,小X越不开心。他希望能够在规定时间内到达T市的同时,使缴纳过路费最多的那次最少。
Input
输入包含不超过10组数据。
对于每组数据,第一行5个正整数,N,M,S,T,L(N≤10000;M≤50000;S≤N;T≤N;L≤1000000000),意义如上文所述。接下来的1行有N个正整数,第i个数表示经过城市i需要缴纳的过路费Fi(Fi≤1000000000)。接下来M行,每行3个正整数Ui,Vi,Wi,(Ui≤N;Vi≤N;Wi≤1000000000)描述一条公路,表示从城市Ui到城市Vi需要花费Wi的时间。
Output
对于每组数据,输出一行一个正整数,表示小X交费最多的那次的最小值。如果小X无论如何也无法在规定时间内到达城市T,输出-1。
Sample Input
4 4 1 4 10
3 6 9 3
1 3 1
2 1 3
3 4 5
4 2 7
4 4 1 4 4
3 6 9 3
1 3 1
2 1 3
3 4 5
4 2 7
5 5 1 4 6
3 6 9 3 6
1 3 1
2 1 3
3 4 5
4 5 1
5 2 2
Sample Output
6
-1
6
题解
过路费最多的那次最少,很容易想到二分答案,然后检查,检查就跑一边dijkstra,在跑的时候加入条件边权必须小于mid,最后判断一下d[t]是否大于L,大于的话就l = mid + 1,否则r = mid - 1,记录一下ans即可
AC代码
#include<bits/stdc++.h>
#define ll long long
#define maxn 100050
#define pi pair<int, int>
using namespace std;
inline ll getnum() {
ll ans = 0; char c; ll flag = 1;
while (!isdigit(c = getchar()) && c != '-');
if (c == '-') flag = -1; else ans = c - '0';
while (isdigit(c = getchar())) ans = ans * 10 + c - '0';
return ans * flag;
}
struct node {
ll v, w;
node(ll vv, ll ww) {
v = vv;
w = ww;
}
};
vector<node> G[maxn];
void adde(ll a, ll b, ll w) {
G[a].push_back(node(b, w));
G[b].push_back(node(a, w));
}
ll n, m, s, t, l;
ll w[maxn];
ll dp[maxn];
ll maxw;
ll d[maxn], vis[maxn];
int dijkstra(int mid, int s) {
priority_queue<pi, vector<pi>, greater<pi> > q;
fill(d + 1, d + n + 1, 0x7fffffffffffffff);
d[s] = 0;
fill(vis + 1, vis + n + 1, false);
q.push(make_pair(d[s], s));
while (!q.empty()) {
pi now = q.top(); q.pop();
int x = now.second;
if (vis[x]) continue;
vis[x] = true;
if (w[x] > mid) continue;
for (int i = 0; i < G[x].size(); i++) {
int v = G[x][i].v, wi = G[x][i].w;
if (d[v] > d[x] + wi && w[v] <= mid && d[x] + wi <= l) {
d[v] = d[x] + wi;
q.push(make_pair(d[v], v));
}
}
}
if (d[t] > l) return 0;
else return 1;
}
int main() {
while (scanf("%lld%lld%lld%lld%lld", &n, &m, &s, &t, &l) != EOF) {
maxw = 0;
for (int i = 1; i <= n; i++) {
w[i] = getnum();
maxw = max(maxw, w[i]);
}
for (int i = 1; i <= n; i++) {
G[i].clear();
}
for (int i = 1; i <= m; i++) {
ll a, b; ll wi;
a = getnum(), b = getnum(), wi = getnum();
adde(a, b, wi);
}
ll li = 0, r = maxw + 100, mid = -1;
ll ans = 0x7fffffffffffffff;
while (li <= r) {
mid = (li + r) >> 1;
if (dijkstra(mid, s)) {
r = mid - 1;
ans = min(ans, mid);
}
else li = mid + 1;
}
if (li > maxw) cout << "-1" << endl;
else cout << ans << endl;
}
return 0;
}
/**********************************************************************
Problem: 1989
User: Artoriax
Language: C++
Result: AC
Time:328 ms
Memory:10664 kb
**********************************************************************/
CSU-1989 赶路的小X的更多相关文章
- CSU 1777: 大还是小?【模拟/后导0】
293419 roniking 1777 Accepted 2032 0 C++ 2000 2018-04-03 19:21:25 Description 输入两个实数,判断第一个数大,第二个数大还是 ...
- csu 1982:小M的移动硬盘(双向链表)
Description 最近小M买了一个移动硬盘来储存自己电脑里不常用的文件.但是他把这些文件一股脑丢进移动硬盘后,觉得这些文件似乎没有被很好地归类,这样以后找起来岂不是会非常麻烦? 小M最终决定要把 ...
- csu 1976: 搬运工小明
1976: 搬运工小明 Submit Page Summary Time Limit: 2 Sec Memory Limit: 128 Mb Submitted: 94 ...
- CSU 1802 小X的战斗力【拓扑dp】
题目链接 题意:n个人,每个人有一个能力值.给出m组关系A, B, 表示A的能力值大于B的能力值. 问:m组关系中是否有自相矛盾的?若不矛盾,问:第1个人在所有人的能力值中排名第几?有多少人的能力值的 ...
- 微信小程序导航:官方工具+精品教程+DEMO集合(1月7更新)
1:官方工具:https://mp.weixin.qq.com/debug/w ... tml?t=14764346784612:简易教程:https://mp.weixin.qq.com/debug ...
- csu oj 1811: Tree Intersection (启发式合并)
题目链接:http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1811 给你一棵树,每个节点有一个颜色.问删除一条边形成两棵子树,两棵子树有多少种颜色是有 ...
- csu 1312 榜单(模拟题)
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1312 1312: 榜单 Time Limit: 1 Sec Memory Limit: 128 ...
- poj 2528 线段树 离散化的小技巧
题意:在墙上贴海报,海报可以互相覆盖,问最后可以看见几张海报思路:直接搞超时+超内存,需要离散化.离散化简单的来说就是只取我们需要的值来 用,比如说区间[1000,2000],[1990,2012] ...
- csu 10月 月赛 A 题
Welcome to CSU OnlineJudge Problem A: Small change Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 15 ...
随机推荐
- set方法的使用
<div id='root'> <div v-for='(item,key,index) of userInfo'> {{item}}--{{key}}--{{index}} ...
- 【转】WebSocket 是什么原理?为什么可以实现持久连接?
WebSocket是HTML5出的东西 也就是说HTTP协议没有变化 但HTTP是不支持持久连接的(长连接,循环连接的不算)或者说WebSocket干脆就不是基于HTTP来执行的.但是...说不通啊. ...
- 【造轮子】开发vue组件库MeowMeowUI
项目示例 github 1. 创建项目 # 全局安装 vue-cli $ npm install --global vue-cli # 创建一个基于 webpack 模板的新项目 $ vue in ...
- cudaMalloc和cudaMallocPitch
原文链接 偶有兴趣测试了一下题目中提到的这两个函数,为了满足对齐访问数据,咱们平时可能会用到cudamallocPitch,以为它会带来更高的效率.呵呵,这里给出一段测试程序,大家可以在自己的机器上跑 ...
- Meshlab
打开ply文件的软件,Meshlab. 下载 http://yunpan.cn/cgapukD2La9Se (提取码:37f1) http://pan.baidu.com/s/1pJLnWqJ
- Entityframework对应sqlserver版本问题
修改.edmx文件中 providermanifesttoken 的值
- vs2012或vs2013调试卡 关闭调试卡
以前vs2013就有这个问题.没有解决.今天又装了vs2012.又遇到了.特别郁闷. 今天一定要解决.网上百度了.很久.可能关键字有问题.没有找到好的办法. 找到的办法有.显卡问题.不是管理员运行问题 ...
- 友盟分享小结 - iOS
因之前都写在了 AppDelegate 类中,看起来过于臃肿,此次基于友盟分享重新进行了一次优化,此次分享内容基于已经成功集成 SDK 后 code 层级部分.注:此次分享基于 SDK 6.9.3,若 ...
- mpvue重构小程序之坑点1
对于最近刚做的项目,想着用框架重新架构一遍,方便以后拓展,毕竟现在拓展方向非常大. 目前主要碰到两个略坑的问题: 1: 关于用户授权信息的按钮,原生是以下方式,使用bindgetuserinfo事件 ...
- 【杂题总汇】HDU多校赛第十场 Videos
[HDU2018多校赛第十场]Videos 最后一场比赛也结束了…… +HDU传送门+ ◇ 题目 <简要翻译> 有n个人以及m部电影,每个人都有一个快乐值.每场电影都有它的开始.结束时间和 ...