【NOIP2019模拟2019.11.13】旅行 && GDKOI2018 还念(二分答案+dij)
Description:

题解:
显然满足二分性。
并且每一条边要不选l要不选r。
二分的那条链肯定要选l。
考虑有两个人在走最短路,一个人一开始必须走二分的那条链,要求第一个人走的比第二个人快。
安排的话也比较简单,第一人先走到这条边就给l,第二个人就给r。
还有一种想法,先只给二分的链l,其它都给r,跑一遍最短路,设为dis1。
然后再从二分的链的结尾开始,每条边都设为l,跑最短路,dis2。
然后一个点x的dis2[x]+二分的链长<=dis1[x],那么就可以走这个点,否则不能走,最后看能不能走到终点。
两个做法本质有一点点相似。
Code:
#include<bits/stdc++.h>
#define fo(i, x, y) for(int i = x, B = y; i <= B; i ++)
#define ff(i, x, y) for(int i = x, B = y; i < B; i ++)
#define fd(i, x, y) for(int i = x, B = y; i >= B; i --)
#define ll long long
#define pp printf
#define hh pp("\n")
using namespace std;
const int N = 2e5 +5;
int n, m, p, b[N];
struct edge {
int x, y, l, r;
} a[N];
int fi[N], nt[N], to[N], tot;
void link(int x, int y) {
nt[++ tot] = fi[x], to[tot] = y, fi[x] = tot;
}
struct P {
int x; ll y;
P(int _x = 0, ll _y = 0) {
x = _x, y = _y;
}
};
bool operator < (P a, P b) {
return a.y > b.y;
}
priority_queue<P> q;
int ky[N];
ll dis[N], dis2[N];
int us[N][2];
int pd(int mi) {
fo(i, 1, n) fo(j, 0, 1) us[i][j] = 0;
fo(i, 1, m) ky[i] = 0;
fo(i, 1, mi) ky[b[i]] = 1;
fo(i, 1, n) dis[i] = dis2[i] = 1e18;
ll sb = 0; dis[1] = 0;
fo(i, 1, mi) {
sb += 2 * a[b[i]].l;
dis[a[b[i]].y] = sb;
if(i < mi && a[b[i]].y == 2) return 0;
}
q.push(P(a[b[mi]].y, sb));
dis2[1] = 1; q.push(P(1, 1));
while(q.size()) {
P b;
while(q.size()) {
b = q.top(); q.pop();
if(us[b.x][b.y & 1]) continue;
break;
}
if(us[b.x][b.y & 1]) continue;
us[b.x][b.y & 1] = 1;
for(int i = fi[b.x]; i; i = nt[i]) {
int y = to[i];
ll z = b.y;
if(!ky[i]) ky[i] = (b.y & 1) + 1;
z += ky[i] == 1 ? a[i].l * 2 : a[i].r * 2;
if(b.y & 1) {
if(z < dis2[y]) {
dis2[y] = z;
q.push(P(y, dis2[y]));
}
} else {
if(z < dis[y]) {
dis[y] = z;
q.push(P(y, dis[y]));
}
}
}
}
return dis[2] <= dis2[2];
}
int main() {
freopen("travel.in", "r", stdin);
freopen("travel.out", "w", stdout);
scanf("%d %d %d", &n, &m, &p);
fo(i, 1, m) {
scanf("%d %d %d %d", &a[i].x, &a[i].y, &a[i].l, &a[i].r);
link(a[i].x, a[i].y);
}
fo(i, 1, p) scanf("%d", &b[i]);
int as = 0;
for(int l = 1, r = p; l <= r; ) {
int mi = l + r >> 1;
if(pd(mi)) l = mi + 1; else as = mi, r = mi - 1;
}
if(as == 0) pp("No Response!\n"); else pp("%d\n", b[as]);
}
【NOIP2019模拟2019.11.13】旅行 && GDKOI2018 还念(二分答案+dij)的更多相关文章
- 6424. 【NOIP2019模拟2019.11.13】我的订书机之恋
题目描述 Description Input Output Sample Input 见下载 Sample Output 见下载 Data Constraint 题解 lj题卡线段树 求出每个右端点往 ...
- 「考试」noip模拟9,11,13
9.1 辣鸡 可以把答案分成 每个矩形内部连线 和 矩形之间的连线 两部分 前半部分即为\(2(w-1)(h-1)\),后半部分可以模拟求(就是讨论四种相邻的情况) 如果\(n^2\)选择暴力模拟是有 ...
- 6362. 【NOIP2019模拟2019.9.18】数星星
题目描述 题解 一种好想/好写/跑得比**记者还快的做法: 对所有询问排序,按照R递增的顺序来处理 维护每个点最后一次被覆盖的时间,显然当前右端点为R时的答案为所有时间≥L的点的权值之和 LCT随便覆 ...
- 【NOIP2019模拟2019.10.07】果实摘取 (约瑟夫环、Mobius反演、类欧、Stern-Brocot Tree)
Description: 小 D 的家门口有一片果树林,果树上果实成熟了,小 D 想要摘下它们. 为了便于描述问题,我们假设小 D 的家在二维平面上的 (0, 0) 点,所有坐标范围的绝对值不超过 N ...
- 6383. 【NOIP2019模拟2019.10.07】果实摘取
题目 题目大意 给你一个由整点组成的矩形,坐标绝对值范围小于等于\(n\),你在\((0,0)\),一开始面向\((1,0)\),每次转到后面第\(k\)个你能看到的点,然后将这条线上的点全部标记删除 ...
- 6380. 【NOIP2019模拟2019.10.06】小w与最长路(path)
题目 题目大意 给你一棵树,对于每一条边,求删去这条边之后,再用一条边(自己定)连接两个连通块,形成的树的直径最小是多少. 正解 首先,将这棵树的直径给找出来.显然,如果删去的边不在直径上,那么答案就 ...
- 6371. 【NOIP2019模拟2019.9.28】基础图论练习题
题目 题目大意 维护一个无向图的割边条数,支持加边和删边. 正解 (PS:这是我很久之前在OJ上打出来的题解,现在直接copy过来) 题解只有一句话,估计没多少人可以看得懂.感觉出题人偷懒不想写题解- ...
- 6368. 【NOIP2019模拟2019.9.25】质树
题目 题目大意 有个二叉树,满足每个点跟它的所有祖先互质. 给出二叉树的中序遍历的点权,还原一种可能的方案. 思考历程 首先想到的当然是找到一个跟全部互质的点作为根,然后左右两边递归下去处理-- 然而 ...
- 6367. 【NOIP2019模拟2019.9.25】工厂
题目 题目大意 给你一堆区间,将这些区间分成特定的几个集合,使得每个集合中的所有区间的并不为空. 求最大的每组区间的交的长度之和. 思考历程 一开始就认为这绝对是\(DP\)-- 试着找一些性质,结果 ...
随机推荐
- [转]Win10企业版无法访问共享文件夹
Win10系统电脑在更新后,当我们访问共享文件夹时可能会出现如下图所示窗口,导致我们无法访问.那么这个问题如何解决呢?具体如下:1. 首先我们按“Windows+R键”打开运行窗口.2. 在该窗口文本 ...
- SpringMvc的过滤器。
一:过滤器的原理: 过滤器放在web资源之前,可以在请求抵达它所应用的web资源(可以是一个Servlet.一个Jsp页面,甚至是一个HTML页面)之前截获进入的请求,并且在它返回到客户之前截获输出请 ...
- Delphi Base64编码/解码
Uses CnBase64: CnBase64.Base64Encode(Edit1.Text, Psw64);
- HihoCoder - 1664 (单调队列)
题目:https://vjudge.net/contest/319166#problem/B 题意: 一个01间隔矩阵,求一个方阵的最大边长,这个方阵的要求是里面01分隔,不能有01相邻 思路:同 ...
- LintCode之回文数
题目描述: 我的代码: public class Solution { /* * @param num: a positive number * @return: true if it's a pal ...
- EasyUI 中的双击某行 并赋值给input事件
项目是由mvc+easyUI开发,双击事件在下边.有注释写着呢 function DataList(supCode) { myDatagrid2.datagridId = "GridView ...
- English-Useful sentences
很乐意 pull request. Pleased to pull request. 这个项目现在已经被弃用了. This project is now deprecated. 如你下面看到的,你可以 ...
- Python 进阶_闭包 & 装饰器
目录 目录 闭包 函数的实质和属性 闭包有什么好处 小结 装饰器 更加深入的看看装饰器的执行过程 带参数的装饰器 装饰器的叠加 小结 装饰器能解决什么问题 小结 闭包 Closure: 如果内层函数引 ...
- CSS属性去除图片链接时的虚线框
CSS 之outline (轮廓)是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用.outline 属性是一个简写属性,用于设置元素周围的轮廓线.注释:轮廓线不会占据空间,也不一定是 ...
- 【excel】 超链接相关
如何导出超链接: 用visual basic处理 在excel中:Alt+F11 --> F7 --> 粘贴下面代码 -->F5(运行), 则会在原列接右侧出现超链 Sub Ext ...