P7167 Fountain
有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的更多相关文章
- 洛谷P7167 [eJOI 2020 Day1] Fountain (单调栈+ST)
开两个数组:to[i][j]表示从i这个位置向下的第2j个圆盘是哪个,f[i][j]表示流满从i这个位置向下的 2j 个圆盘需要多少体积的水. 详情见代码: 1 #include<bits/st ...
- [AtCoder 2702]Fountain Walk - LIS
Problem Statement In the city of Nevermore, there are 108 streets and 108 avenues, both numbered fro ...
- 【xsy1503】 fountain DP
题目大意:给你$D$个格子,有$n$个喷水器,每个喷水器有一个喷水距离$r_i$. 现在你需要在这$D$个格子中选择$n$个位置按照任意顺序安装这$n$个喷水器,需要满足$n$个喷水器互相喷不到对方. ...
- 【agc019C】Fountain Walk
Portal --> agc019C Description 有一个\(10^8*10^8\)的网格图,一格距离为\(100\),第\(x\)条竖线和第\(y\)条横线的交点记为\((x,y)\ ...
- Agc019_C Fountain Walk
传送门 题目大意 给定网格图上起点和终点每个格子是长为$100$米的正方形,你可以沿着线走. 平面上还有若干个关键点,以每个关键点为圆心,$10$为半径画圆,表示不能进入圆内的线,但是可以从圆周上走, ...
- Yeoman 官网教学案例:使用 Yeoman 构建 WebApp
STEP 1:设置开发环境 与yeoman的所有交互都是通过命令行.Mac系统使用terminal.app,Linux系统使用shell,windows系统可以使用cmder/PowerShell/c ...
- CSharpGL(23)用ComputeShader实现一个简单的ParticleSimulator
CSharpGL(23)用ComputeShader实现一个简单的ParticleSimulator 我还没有用过Compute Shader,所以现在把红宝书里的例子拿来了,加入CSharpGL中. ...
- [Erlang 0114] Erlang Resources 小站 2013年7月~12月资讯合集
Erlang Resources 小站 2013年7月~12月资讯合集,方便检索. 附 2013上半年盘点: Erlang Resources 小站 2013年1月~6月资讯合集 小站地 ...
- HTML5资料
1 Canvas教程 <canvas>是一个新的用于通过脚本(通常是JavaScript)绘图的HTML元素.例如,他可以用于绘图.制作图片的组合或者简单的动画(当然并不那么简单).It ...
- RainCup_No.1
Rain杯No.1 初见篇 本系列故事以及人名地名等纯属虚构,如有雷同,纯属巧合 在极东之地,有一个岛国,与岛国隔了一个海域有一个古老的国度,天朝.天朝T镇有个少年叫小S,故事从小S与少女Rain的相 ...
随机推荐
- 几行代码教你快速创建scrapy项目,非常实用建议收藏!
import shutil,os修改settings.py def config(scrapy_path,project_name): judge=input("是否自动修改配置?是:yes ...
- Redis之消息队列实现
文章目录 秒杀场景 采用消息队列实现 List实现消息队列 PubSub(发布订阅)实现消息队列 基于Stream实现消息队列 消费者组 实践 总结 秒杀问题是非常重要且比较难实现的,如果不进行架构的 ...
- 在Bamboo上怎么使用iOS的单元测试
作者:京东零售 吴滔 本教程将使用北汽登录模块为例,一步一步和大家一起搭建单元测试用例,并在Bamboo上跑起来,最终测试结果和代码覆盖率会Bamboo上汇总. 模块名称:BQLoginModule, ...
- 音视频八股文(8)-- h264 AnnexB三层结构
NALU(Network Abstract Layer Unit) ⾳视频编码在流媒体和⽹络领域占有重要地位:流媒体编解码流程⼤致如下图所示: H264简介 H.264从1999年开始,到2003年形 ...
- 2022-09-18:以下go语言代码输出什么?A:1;B:15;C:panic index out of range;D:doesn’t compile。 package main import
2022-09-18:以下go语言代码输出什么?A:1:B:15:C:panic index out of range:D:doesn't compile. package main import ( ...
- Springboot通过谷歌Kaptcha 组件,生成图形验证码
图形验证码属于老生常谈了,具体细节这里就不说了.生成图形验证码的办法非常多,今天讲解一种通过Kaptcha组件快速生成图形验证码的方法.Kaptcha是谷歌开源的一款简单实用的图形验证码组件.我个人推 ...
- 小程序使用wx.navigateTo无法跳转到加了tabBar的页面
随着小程序的不断更新,发现目前的小程序版本使用navigator无法跳转到加了tabBar的页面:后来使用redirectTo进行跳转也不行:在刚开始也是纠结了好久一直找不到解决办法.最后从官方文档中 ...
- iOS中容易用错的常用知识点
坐标系转换 ios中的坐标系有三种 视图坐标系:原点(0,0)视图的左上角 窗口坐标系:原点(0,0)窗口的左上角 世界坐标系:原点(0,0)游戏中世界的原点 平时开发中经常会遇到转UIWindow坐 ...
- tryhackme-Agent Sudo
描述:您在深海下发现了一个秘密服务器.你的任务是侵入服务器内部并揭露真相. 枚举 nmap -sV -T4 -v 10.10.123.164 NSE: Script scanning 10.10.12 ...
- 用声明式宏解析 Rust 语法
在上一篇 Rust 声明式宏中的 Metavariables 有哪些 的基础上, 今天尝试解析一下 Rust 中的几种 item.我们知道一个 crate 是由 item 组成的,每一个 fn str ...