AT2401 [ARC072C] Alice in linear land
基于观察,可以发现这样一条性质:
- 我们并不关心当前位置和终点的绝对关系,只在乎当前位置和终点的距离,当这个距离确定的时候接下来能走到的位置也是确定的。
基于这个观察可以发现,本质上每个位置的状态就是和终点的距离。
进一步可以发现,对于一个查询 \(q = x\) 假设在 \(x - 1\) 已经到达了 \(p\) 位置,那么我们一定可以在 \(x\) 这个位置通过调整使得经过 \(x\) 后距离终点的距离为 \([0, p]\) 中任意一个数。
于是问题就转化为,是否存在 \([0, p]\) 中的一个距离 \(d\) 使得从 \(x + 1\) 开始往后走不能到达终点。
可以发现,对于前者从 \(1\) 走到 \(x - 1\) 后距离终点的距离是很好计算的。
直接令 \(f_i\) 表示 \(1\) 走到 \(i\) 后到终点的距离,则 \(f_i = \min(f_{i - 1}, |f_{i - 1} - a_i|)\)
重头戏在后面部分,如何求出对于每个起点距离终点 \(d\) 从 \(i\) 往后走能否到达终点呢?
同样考虑直接令 \(g_{i, j}\) 表示起点距离终点 \(j\),从 \(i\) 往后走能否走到终点。
那么就会有转移:
g_{i, j} =
\begin{cases}
g_{i + 1, j} (a_i >= 2 \times j) \\
g_{i + 1, a_i - j} (j \le a_i < 2 \times j) \\
g_{i + 1, j - a_i} (a_i < j)
\end{cases}
\end{aligned}
\]
但是这样求是 \(O(nD)\) 的,显然不可取。
可以发现,问题在于我们不能计算出所有的距离 \(d\) 是否能到达。
于此同时又可以发现,我们并不需要知道所有的距离 \(d\) 是否能到达,只需要知道是否存在一个在 \([0, f_{i - 1}]\) 内的距离即可。
因此,为了尽可能满足在这个范围之内,我们只需要贪心地选取最小的哪个满足条件的距离,判断其是否在这个区间即可。
顺着这个思路考虑改写一下所求,令 \(g_i\) 表示最小的距离 \(d\) 使得 \(i\) 往后不能到达终点。
下面考虑转移,同样还是考虑分走或不走转移。
继续观察可以发现 \(\forall i, g_i \ge g_{i + 1}\),因此为了使得 \(g_i\) 最小应该尽量使得其不走动。
所以,当 \(a_i \ge 2 \times g_{i}\) 时,\(g_i = g_{i + 1}\),因为我们只知道 \(g_{i + 1}\),因此判定条件改为 \(a_i \ge 2 \times g_{i + 1}\)。
那么当 \(a_i < 2 \times g_{i + 1}\) 时,\(g_i \ge g_{i + 1} + a_i\);否则 \(g_i < g_{i + 1} + a_i \Rightarrow g_i - a_i < g_{i + 1}\) 同时 \(g_i - a_i\) 也是不合法的,与 \(g_{i + 1}\) 已经最小矛盾。
同时,这个下界显然是可以取到的,因此 \(g_i = g_{i + 1} + a_i(a_i < 2 \times g_{i + 1})\)
显然初始值 \(g_{n + 1} = 1\)。
最后查询直接判断是否 \(g_{q + 1} \le f_{q - 1}\) 即可,复杂度 \(O(n + q)\)。
#include <bits/stdc++.h>
using namespace std;
#define int long long
#define rep(i, l, r) for (int i = l; i <= r; ++i)
#define dep(i, l, r) for (int i = r; i >= l; --i)
const int N = 5e5 + 5;
const int inf = 1e9;
int n, q, D, x, a[N], f[N], g[N];
int read() {
char c; int x = 0, f = 1;
c = getchar();
while (c > '9' || c < '0') { if(c == '-') f = -1; c = getchar();}
while (c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
signed main() {
n = read(), D = read();
rep(i, 1, n) a[i] = read();
f[0] = D, g[n + 1] = 1;
rep(i, 1, n) f[i] = min(f[i - 1], abs(f[i - 1] - a[i]));
dep(i, 1, n) g[i] = (a[i] >= 2 * g[i + 1] ? g[i + 1] : g[i + 1] + a[i]);
q = read();
while (q--) x = read(), printf(g[x + 1] <= f[x - 1] ? "YES\n" : "NO\n");
return 0;
}
当要求某个范围内是否存在合法的数时,往往可以求某个特殊的合法的值,判断其是否在范围内即可。
比如 \([0, x]\) 内求最小,\([x, +\infty)\) 求最大。
AT2401 [ARC072C] Alice in linear land的更多相关文章
- [AT2401] [arc072_e] Alice in linear land
题目链接 AtCoder:https://arc072.contest.atcoder.jp/tasks/arc072_c 洛谷:https://www.luogu.org/problemnew/sh ...
- ARC072E Alice in linear land
---题面--- 题解: 首先我们要观察到一个性质,因为在固定的起始距离下,经过固定的操作,最后所在的位置是固定的,我们设经过操作1 ~ i之后所在的地方距离终点为d[i]. 那么如果女巫可以修改第i ...
- 【ARC072E】Alice in linear land DP
题目大意 有一个人要去直线上\(lm\)远处的地方,他会依次给他的机器发出\(n\)个指令.第\(i\)个指令为\(d_i\).他的机器收到一个指令\(x\)后,如果向目的地方向前进\(xm\)后比当 ...
- AtCoder Regular Contest 072 E:Alice in linear land
题目传送门:https://arc072.contest.atcoder.jp/tasks/arc072_c 题目翻译 给你一个数组\(D\),然后给你一个操作序列\(d\),每次操作可以将\(D\) ...
- 【ARC072 E】Alice in linear land
被智商题劝退,告辞 题意 有一个人在一条数轴的距离原点为 \(D\) 的位置,他可以执行 \(n\) 次操作,每次操作为给定一个整数 \(d_i\),这个人向原点的方向走 \(d_i\) 个单位,但如 ...
- 【ARC072E】Alice in linear land
题目 瑟瑟发抖,这竟然只是个蓝题 题意大概就是初始在\(0\),要到坐标为\(D\)的地方去,有\(n\)条指令,第\(i\)条为\(d_i\).当收到一条指令\(x\)后,如果向\(D\)方向走\( ...
- 【arc072e】AtCoder Regular Contest 072 E - Alice in linear land
题意 给定一个D,以及一个长度为N的序列a,顺序执行这些数字: 对于一个数字x,会使得D=min(D,abs(D-x)) 有Q次询问,每次询问独立,给出i,能否修改a[i],使得D最后不为0. n,q ...
- Atcoder Regular Contest 072 C - Alice in linear land(思维题)
Atcoder 题面传送门 & 洛谷题面传送门 首先求出 \(s_i\) 表示经过 \(i\) 次操作后机器人会位于什么位置,显然 \(s_0=D\),\(s_i=\min(s_{i-1},| ...
- 【AtCoder】ARC072
ARC072 C - Sequence 直接认为一个数是正的,或者第一个数是负的,每次将不合法的负数前缀和改成+1正数前缀和改成-1 #include <bits/stdc++.h> #d ...
随机推荐
- 使用 jQuery 选择器获取页面元素,然后利用 jQuery 对象的 css() 方法设置其 display 样式属性,从而实现显示和隐藏效果。
查看本章节 查看作业目录 需求说明: 使用 jQuery 选择器获取页面元素,然后利用 jQuery 对象的 css() 方法设置其 display 样式属性,从而实现显示和隐藏效果. 具体要求如下: ...
- 编写Java程序,使用JFrame创建一个窗体
返回本章节 返回作业目录 需求说明: 使用JFrame创建一个窗体 实现思路: 使用JFrame创建窗体的思路 定义一个窗体对象f,窗体名称为"一个简单窗口" 设置窗体左上角与显示 ...
- WiFi6模块 RW6852-PCIE
RW6852-PCIE是一款高度集成的模块,支持2T2R 802.11ax解决方案,具有MU-MIMO.无线LAN (WLAN) PCI Express网络接口控制器和HS-UART混合接口.它结合了 ...
- Log4j2基本使用入门
1.Log4j2简介 Apache Log4j 2是日志框架Log4j的升级, 它比其前身Log4j 1.x提供了重要的改进, 并且参考了Logback中许多有用的改进, 同时修复了Logback的一 ...
- Elasticsearch集群安装Version6.2.2
Elasticsearch集群安装, 基于Elasticsearch6.2.2版本, 在Linux上安装Elasticsearch集群. 1.安装规划 IP HostName Service Mast ...
- PDF的信息提取的问题
PDF对企业应用来说是刚需. 然而PDF显然不是一种对机器友好的格式,它只是对人类友好,就是说方便阅读打印,但让程序去提取其中的内容却很难.下面简单说说为什么是这样. 以前还读书的时候(20+ ...
- zabbix5.0监控安全配置全过程
第一部分,安装 此安装配置为yum方式安装zabbix5.0 系统版本:CentOS Linux release 7.5.1804 (Core) zabbix版本:rpm -qa | grep zab ...
- iNeuOS工业互联网操作系统,增加设备驱动的自定义参数模板,适配行业个性化设备的应用场景
目 录 1. 概述... 2 2. 平台演示... 2 3. 应用过程... 2 1. 概述 增加设备驱动的自定义参数模板,适配行业个性化设备的应用场景. ...
- 适配器模式(pthon)
#!/usr/bin/env python3 # -*- coding: utf-8 -*- # adapter_pattern.py # 适配器模式 class Adaptee: def reque ...
- 【PTA】6-2 读文章(*) (31 分)
请编写函数,从文件中读出文章,将其输出到屏幕上. 函数原型 void ReadArticle(FILE *f); 说明:参数 f 为文件指针.函数读出 f 所指示文件中的文章,将其输出到屏幕上. 裁判 ...