【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\)-- 试着找一些性质,结果 ...
随机推荐
- vue 项目的运行与 打包
1.vue init webpack 2.npm install axios 3.npm run dev 运行项目 4.npm run build 打包项目 会生成一个dist 文件夹,我们只需要把 ...
- Vue学习笔记-组件通信-父传子(props中的驼峰标识)
在组件中,使用选项props来声明需要从父级接收到的数据.props的值有两种方式:方式一:字符串数组,数组中的字符串就是传递时的名称.方式二:对象,对象可以设置传递时的类型,也可以设置默认值等. & ...
- python使用qq邮箱向163邮箱发送邮件、附件
在生成html测试报告后 import smtplib,time from email.mime.text import MIMEText from email.mime.multipart impo ...
- 【LeetCode 76】最小覆盖子串
题目链接 [题解] 尺取法. 用l和r代表一个合法的覆盖子串. 我们不断地扩大右指针. 直到l..r包含T中的所有字母为止(重复的就要两次以上.) 然后我们可以尝试的让l++. 看看新的l..r是不是 ...
- C#生成一个按时间排序的DUID
/// <summary> /// 创建一个按时间排序的Guid /// </summary> /// <returns></returns> publ ...
- UOJ 450 【集训队作业2018】复读机——单位根反演
题目:http://uoj.ac/problem/450 重要式子: \( e^x = \sum\limits_{i=0}^{\infty} \frac{x^i}{i!} \) \( ( e^{a*x ...
- UI:UI 目录
ylbtech-UI:UI 目录 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 6.返回顶部 作者:ylbtech出处:http://ylbtech ...
- 转-调用HTMLTestRunner生成的报告中不能显示用例中print函数的输出
官方原生的HTMLTestRunner.py支持python2.0版本,python3.0版本的使用需要做一些修改: Python3调用HTMLTestRunner执行用例生成测试报告中,不能正常显示 ...
- ---搭建springMvc框架,希望对初学者有所参考
Spring Mvc ==> Struts2 spring 无法替代 myBatis 工作量大 要自己操作sql语句 ==> hibernate Spring Mvc 取代St ...
- Redis 系列
Redis 系列 [Redis 系列(01)安装配制] [Redis 系列(02)数据结构] [Redis 系列(03-1)进阶 - 发布订阅] [Redis 系列(03-2)进阶 - 事务] [Re ...