原题

有n个盘子组成的塔,向第i个盘子上倒水,若溢出会落到下面第一个直径大的盘子里,直到落到底部的水池为止。现给出q次询问,\((r,v)\)代表向第r个盘子里倒入体积为v的水,求水最终会停在哪个盘子

一开始用ST表保存区间内盘子直径最大值,给出 \(r\) 后,递归求解 \([ r,n ]\) 区间内最大值k,并继续求 \([r,k]\) 区间内最大值,直到取到第 \(r\) 个,回溯过程中逐步计算储水量。

但是看到严格单调递增序列就放弃了

然后卡了一段时间,突然发现好像有点眼熟 (

第一个想法

看正的比较难想,但横过来就很直观

当我们说水向下流,实际上我们在说水向右找到第一个比他大的盘子,那么就是单调栈了

数组 \(f[i]\) 表示第i个盘子下边第一个比他大的盘子编号,这样形成链状的查询,可以依次访问

但数据量太大,时间复杂度还是很高

因此要用倍增,类似ST表的方法,每次跳跃跳2的幂次

数组 \(f[i][j]\) 存储从第i个盘子开始,跳 \(2^j\) 到达的盘子编号

数组 \(summ[i][j]\) 存储从第i个盘子开始,到之上 \(2^j\) 个盘子的储水量总和

查询的时候特判当前储水量,然后从大到小循环j,向上跳跃,最后输出父节点

第二个想法 (但是没写

可以看到在一个大的盘子之上有许多小盘子依次连接,最终汇聚到一个统一的大盘子,又最终汇聚到底部的水池

于是这提醒我们想到树

对于一个盘子,他下面第一个直径大于它的盘子为他的父节点,上面所有可以到达他的盘子为他的子树,根节点代表底部水池

那么从叶节点向上遍历即为流水顺序,在这过程中计算储水量

但是数据太大,所以仍然要用到倍增,使用类似倍增求LCA的方法,向上寻找

但是不是求公共祖先,实质上和第一种方法相同,只不过套上了树的形式

#include <iostream>
#include <cstdio>
#include <cstring>
#include <stack>
#define ll long long
using namespace std;
const int N = 1e5 + 10;
int n, q, d[N], c[N], R, V, f[N][20], summ[N][20];
stack<int>s;
inline void Monotonic_Stack() { // 单调栈板子
for(int i = 1; i <= n; i ++) {
while (!s.empty() && d[i] > d[s.top()]) {
f[s.top()][0] = i; // 初始化右边第一个大的盘子编号
summ[s.top()][0] = c[i]; // 初始化总和
s.pop();
}
s.push(i);
}
while(!s.empty()) f[s.top()][0] = 0, s.pop();
}
inline void PrepareRMQ() { // ST表板子
for (int j = 1; (1 << j) <= n; j ++)
for (int i = 1; i <= n - (1 << j); i ++) {
f[i][j] = f[f[i][j - 1]][j - 1];
summ[i][j] = summ[i][j - 1] + summ[f[i][j - 1]][j - 1];
}
}
inline int query(int r, int val) { // 计算
if (c[r] >= val) return r;
val -= c[r]; // 先减掉当前盘子容量
for (int i = 18; i >= 0; i --)
if (f[r][i] && val > summ[r][i]) {
val -= summ[r][i]; // 向上寻找
r = f[r][i]; // 更新位置
}
return f[r][0]; // 返回父节点
}
int main() {
scanf("%d%d", &n, &q);
for (int i = 1; i <= n; i ++) scanf("%d%d", &d[i], &c[i]);
Monotonic_Stack(); // 单调栈
PrepareRMQ(); // 准备工作
while (q -- ) {
scanf("%d%d", &R, &V);
printf("%d\n", query(R, V));
}
return 0;
}

P7167 Fountain的更多相关文章

  1. 洛谷P7167 [eJOI 2020 Day1] Fountain (单调栈+ST)

    开两个数组:to[i][j]表示从i这个位置向下的第2j个圆盘是哪个,f[i][j]表示流满从i这个位置向下的 2j 个圆盘需要多少体积的水. 详情见代码: 1 #include<bits/st ...

  2. [AtCoder 2702]Fountain Walk - LIS

    Problem Statement In the city of Nevermore, there are 108 streets and 108 avenues, both numbered fro ...

  3. 【xsy1503】 fountain DP

    题目大意:给你$D$个格子,有$n$个喷水器,每个喷水器有一个喷水距离$r_i$. 现在你需要在这$D$个格子中选择$n$个位置按照任意顺序安装这$n$个喷水器,需要满足$n$个喷水器互相喷不到对方. ...

  4. 【agc019C】Fountain Walk

    Portal --> agc019C Description 有一个\(10^8*10^8\)的网格图,一格距离为\(100\),第\(x\)条竖线和第\(y\)条横线的交点记为\((x,y)\ ...

  5. Agc019_C Fountain Walk

    传送门 题目大意 给定网格图上起点和终点每个格子是长为$100$米的正方形,你可以沿着线走. 平面上还有若干个关键点,以每个关键点为圆心,$10$为半径画圆,表示不能进入圆内的线,但是可以从圆周上走, ...

  6. Yeoman 官网教学案例:使用 Yeoman 构建 WebApp

    STEP 1:设置开发环境 与yeoman的所有交互都是通过命令行.Mac系统使用terminal.app,Linux系统使用shell,windows系统可以使用cmder/PowerShell/c ...

  7. CSharpGL(23)用ComputeShader实现一个简单的ParticleSimulator

    CSharpGL(23)用ComputeShader实现一个简单的ParticleSimulator 我还没有用过Compute Shader,所以现在把红宝书里的例子拿来了,加入CSharpGL中. ...

  8. [Erlang 0114] Erlang Resources 小站 2013年7月~12月资讯合集

    Erlang Resources 小站 2013年7月~12月资讯合集,方便检索.     附 2013上半年盘点: Erlang Resources 小站 2013年1月~6月资讯合集    小站地 ...

  9. HTML5资料

    1 Canvas教程 <canvas>是一个新的用于通过脚本(通常是JavaScript)绘图的HTML元素.例如,他可以用于绘图.制作图片的组合或者简单的动画(当然并不那么简单).It ...

  10. RainCup_No.1

    Rain杯No.1 初见篇 本系列故事以及人名地名等纯属虚构,如有雷同,纯属巧合 在极东之地,有一个岛国,与岛国隔了一个海域有一个古老的国度,天朝.天朝T镇有个少年叫小S,故事从小S与少女Rain的相 ...

随机推荐

  1. 推荐Visual Studio四款好用插件

    我要推荐的4个插件,合理使用可以提高工作效率,分别是: 1.Markdown Editor 可以在vs预览markdown文件的插件 2.Add New File 我们原本在vs中新建文件,需要添加新 ...

  2. 2022-11-27:超过经理收入的员工。编写一个SQL查询来查找收入比经理高的员工。以下数据的结果输出是Joe,因为Joe是唯一挣得比经理多的雇员。 DROP TABLE IF EXISTS `em

    2022-11-27:超过经理收入的员工.编写一个SQL查询来查找收入比经理高的员工.以下数据的结果输出是Joe,因为Joe是唯一挣得比经理多的雇员. DROP TABLE IF EXISTS `em ...

  3. defer()排除某些字段

    defer()排除某些字段 不显示nickname,age两列的数据 Student.objects.all().defer('nickname','age')

  4. Django-1:安装、更新、查看版本

    安装: pip install Django 更新: pip3 install -U Django 或者 python -m pip install -U Django 查看: python -m d ...

  5. yaml的读写

    yaml文件的读写是真的快,也很简单.代码如下:from ruamel.yaml import YAMLimport os # 读取yaml配置文件def read_yaml(yaml_path): ...

  6. JS加载机制

    做开发多年后发现自己思维任然只定位在功能的实现:忽略了很多代码最终的实现,加载机制等 那我们接下来就借助几篇博客来理理天天看见的js:理理他究竟是怎么过执行的 一.代码检测 首先浏览器会对所有js 进 ...

  7. 美女同事的烦恼:如何配置 Apache SkyWalking 告警?

    小婉 技术部基本上是一个和尚庙,女生非常少,即使有女生也略微有点抽象,小婉就不一样,她气质绝佳. 上午,同事小婉刚才从老板办公室里出来,看上去一脸不悦的样子.为了表示对同事的关(ba)心(gua),我 ...

  8. ChatGPT教我用200行代码写一个简版Vue框架 - OpenTiny

    AI 是未来最好的老师 最近,我正在准备一份关于 Vue 基础的学习材料.期间我突发奇想:能否利用现在热门的 ChatGPT 帮我创建学习内容?其实 Vue 本身不难学,特别是基础用法,但是,如果你想 ...

  9. 基于Microsoft SEAL 同态加密场景特性

    基于Microsoft SEAL 同态加密场景特性 同态加密是一种特殊的加密技术,它允许在加密状态下进行计算操作而无需解密数据.在传统的加密算法中,对加密的数据进行运算操作通常需要先解密数据,然后再进 ...

  10. [ARM 汇编]进阶篇—存储访问指令—2.3.2 多数据传输指令

    在 ARM 汇编中,多数据传输指令用于一次性从存储器中加载多个数据到寄存器组,或将寄存器组中的多个数据存储到存储器.这些指令通常用于高效地处理数组.结构体等数据结构.在本节中,我们将详细介绍 ARM ...