CF95C Volleyball
题意翻译
给出一个图,双向边,边上有权值代表路的距离,然后每个点上有两个值,t,c,t代表能从这个点最远沿边走t,且不能在半路下来,花费是c 现在告诉你起点终点,问最少的花费 点个数1000,边个数1000,边权1e9
By @partychicken
题目描述
Petya loves volleyball very much. One day he was running late for a volleyball match. Petya hasn't bought his own car yet, that's why he had to take a taxi. The city has n n n junctions, some of which are connected by two-way roads. The length of each road is defined by some positive integer number of meters; the roads can have different lengths.
Initially each junction has exactly one taxi standing there. The taxi driver from the i i i -th junction agrees to drive Petya (perhaps through several intermediate junctions) to some other junction if the travel distance is not more than ti t_{i} ti meters. Also, the cost of the ride doesn't depend on the distance and is equal to ci c_{i} ci bourles. Taxis can't stop in the middle of a road. Each taxi can be used no more than once. Petya can catch taxi only in the junction, where it stands initially.
At the moment Petya is located on the junction x x x and the volleyball stadium is on the junction y y y . Determine the minimum amount of money Petya will need to drive to the stadium.
输入输出格式
输入格式:
The first line contains two integers n n n and m m m ( 1<=n<=1000,0<=m<=1000) 1<=n<=1000,0<=m<=1000) 1<=n<=1000,0<=m<=1000) . They are the number of junctions and roads in the city correspondingly. The junctions are numbered from 1 1 1 to n n n , inclusive. The next line contains two integers x x x and y y y ( 1<=x,y<=n 1<=x,y<=n 1<=x,y<=n ). They are the numbers of the initial and final junctions correspondingly. Next m m m lines contain the roads' description. Each road is described by a group of three integers ui u_{i} ui , vi v_{i} vi , wi w_{i} wi ( 1<=ui,vi<=n,1<=wi<=109 1<=u_{i},v_{i}<=n,1<=w_{i}<=10^{9} 1<=ui,vi<=n,1<=wi<=109 ) — they are the numbers of the junctions connected by the road and the length of the road, correspondingly. The next n n n lines contain n n n pairs of integers ti t_{i} ti and ci c_{i} ci ( 1<=ti,ci<=109 1<=t_{i},c_{i}<=10^{9} 1<=ti,ci<=109 ), which describe the taxi driver that waits at the i i i
-th junction — the maximum distance he can drive and the drive's cost.
The road can't connect the junction with itself, but between a pair of
junctions there can be more than one road. All consecutive numbers in
each line are separated by exactly one space character.
输出格式:
If taxis can't drive Petya to the destination point, print "-1" (without the quotes). Otherwise, print the drive's minimum cost.
Please do not use the %lld specificator to read or write 64-bit
integers in С++. It is preferred to use cin, cout streams or the %I64d
specificator.
输入输出样例
4 4
1 3
1 2 3
1 4 1
2 4 1
2 3 5
2 7
7 2
1 2
7 7
9
说明
An optimal way — ride from the junction 1 to 2 (via junction 4), then from 2 to 3. It costs 7+2=9 bourles.
Solution:
本题水。
点数很小,先从每个点暴力最短路处理出该点的t范围内能到的点,并且建一张新图,然后只要在新图上再跑一遍最短路就好了。
代码:
/*Code by 520 -- 8.21*/
#include<bits/stdc++.h>
#define il inline
#define ll long long
#define RE register
#define For(i,a,b) for(RE int (i)=(a);(i)<=(b);(i)++)
#define Bor(i,a,b) for(RE int (i)=(b);(i)>=(a);(i)--)
using namespace std;
const int N=;
int n,m,s,t,a[N],b[N];
int to[N],net[N],w[N],h[N],cnt;
int To[N],Net[N],W[N],H[N],Cnt;
ll dis[N];
bool vis[N];
struct node{
int u;
ll d;
bool operator<(const node &a)const{return d>a.d;}
}; int gi(){
int a=;char x=getchar();
while(x<''||x>'')x=getchar();
while(x>=''&&x<='')a=(a<<)+(a<<)+(x^),x=getchar();
return a;
} il void add(int u,int v,int c){to[++cnt]=v,net[cnt]=h[u],w[cnt]=c,h[u]=cnt;} il void Add(int u,int v,int c){To[++cnt]=v,Net[cnt]=H[u],W[cnt]=c,H[u]=cnt;} queue<int>q;
il void spfa(int x){
For(i,,n) dis[i]=;
q.push(x),dis[x]=;
while(!q.empty()){
int u=q.front();q.pop();vis[u]=;
for(RE int i=h[u];i;i=net[i])
if(dis[to[i]]>dis[u]+w[i]){
dis[to[i]]=dis[u]+w[i];
if(!vis[to[i]])q.push(to[i]),vis[to[i]]=;
}
}
For(i,,n) if(i!=x&&dis[i]<=a[x]) Add(x,i,b[x]);
} priority_queue<node>Q;
il void dij(){
For(i,,n) dis[i]=;
dis[s]=,Q.push(node({s,}));
while(!Q.empty()){
node x=Q.top();Q.pop();
if(!vis[x.u]){
vis[x.u]=;
for(RE int i=H[x.u];i;i=Net[i])
if(dis[To[i]]>dis[x.u]+W[i]){
dis[To[i]]=dis[x.u]+W[i];
if(!vis[To[i]]) Q.push(node({To[i],dis[To[i]]}));
}
}
}
} il void init(){
n=gi(),m=gi(),s=gi(),t=gi();
int u,v,c;
For(i,,m) u=gi(),v=gi(),c=gi(),add(u,v,c),add(v,u,c);
For(i,,n) a[i]=gi(),b[i]=gi();
cnt=;
For(i,,n) spfa(i);
dij();
cout<<(dis[t]==?-:dis[t]);
} int main(){
init();
return ;
}
CF95C Volleyball的更多相关文章
- CF 96 D. Volleyball
D. Volleyball http://codeforces.com/contest/96/problem/D 题意: n个路口,m条双向路,每条长度为w.每个路口有一个出租车司机,最多可以乘坐这辆 ...
- Codeforces 96D Volleyball(最短路径)
Petya loves volleyball very much. One day he was running late for a volleyball match. Petya hasn't b ...
- Codeforces 95C Volleyball(最短路)
题目链接:http://codeforces.com/problemset/problem/95/C C. Volleyball time limit per test 2 seconds memor ...
- Codeforces Beta Round #77 (Div. 1 Only) C. Volleyball (最短路)
题目链接:http://codeforces.com/contest/95/problem/C 思路:首先dijkstra预处理出每个顶点到其他顶点的最短距离,然后如果该出租车到某个顶点的距离小于等于 ...
- *[hackerrank]Volleyball Match
https://www.hackerrank.com/contests/w1/challenges/volleyball-match 此题不错,首先可以看出是DP,S(x, y)= S(x - 1, ...
- CF - 96D - Volleyball
题意:一个无向图,有n个点,m条边,每条边有距离w,每个点有两个属性(1.从这点出发能到的最远距离,2.从这点出发的费用(不论走多远都一样)),一个人要从点x到点y,问最小费用是多少. 题目链接:ht ...
- 【日常训练】Volleyball(CodeForces-96D)
题意与分析 这题也是傻逼题,可是我当时打比赛的时候板子出问题了- -|||,怎么调也调不过. 不过思路是很清晰的:先做n次dijkstra然后重新建图,建完了以后根据新的单向图再跑一次dijkstra ...
- 【codeforces 95C】Volleyball
[题目链接]:http://codeforces.com/problemset/problem/95/C [题意] 给你n个点,m条边; 每个点有一辆出租车; 可以到达离这个点距离不超过u的点,且在这 ...
- mongo学习笔记(一):增删改查
安装:我是按这篇来弄的 一.Insert 1.db.person.insert({"name":"jack","age":20}) 2.va ...
随机推荐
- iOS----------关于Cornerstone的偏好设置
应用场景:有时候我们的项目会导入一些第三方.a文件,但是当我们在svn上check out下来的时候,会发现少了一些.a文件.于是乎项目就报错了. 针对这种情况,我们应该怎么办呢? 1.先打开Corn ...
- iOS----------检测app进入后台或前台
开发播放器的时候,经常需要检测app进入后台(暂停播放)或者进入前台(开始播放).方法非常简单. 1.检测app进入后台 // 在AppDelete实现该方法 - (void)applicationD ...
- 如何在linux下使用sudo命令不用输入密码
用过linux的小伙伴可能都知道,每次使用sudo的时候需要输入密码,这样很耽误事,那么接下来我会教大家如何去设置 一.1.输入su root进入root模式 2.输入visudo会打开/etc/su ...
- (转)hibernateTools工具安装及使用总结(eclipse 3.6)
最近项目采用flex+spring+hibernate的框架开发,之前虽说有多年的Java开发经验了,但是一直使用的JDBC或者 ibatis,hibernate的使用还是大姑娘上轿头一回,网上都介绍 ...
- 如何在MongoDB设计存储你的数据(JSON化)?
第一步 定义要描述的数据集 当我们决定将数据存储下来的时候,我们首先要回答的一个问题就是:“我打算存储什么样的数据?这些数据之间有什么关系?实体之间有什么关系?实体的属性之间有什么关系”. 为了说明问 ...
- SQLServer之删除函数
删除函数注意事项 从当前数据库中删除一个或多个用户定义函数.DROP 函数支持本机编译的标量用户定义函数. 如果数据库中存在引用 DROP FUNCTION 的 Transact-SQL 函数或视图并 ...
- postgreSQL备份数据
1.pg_dump 备份单一数据库 pg_dump仅导出数据库结构: pg_dump -U TestRole1 -s -f TestDb1.sql TestDb1 2.全部备份采用pg_dumpall ...
- Canadian-dollar_RMB
import pandas as pd import matplotlib.pyplot as plt import statsmodels as sm from statsmodels.graphi ...
- mysql导出表的字段及相关属性
需要导出数据库中表的字段及属性,制成表格保存到word中 首先找到要导的库, 在查询页面输入sql SELECT COLUMN_NAME 列名, COLUMN_TYPE 数据类型, DATA_TYPE ...
- Python基础之面对对象进阶
阅读目录 isinstance和issubclass 反射 setattr delattr getattr hasattr __str__和__repr__ __del__ item系列 __geti ...