AT_abc389_f [ABC389F] Rated Range 题解

题目传送门

前置知识

Treap | 线段树

解法

考虑将询问的 \(x\) 离线下来在升序排序后一起处理。

观察到每次操作只有 \(+1\),即其之间的相对大小关系不会发生变化,此时就只需要支持将值在 \([l,r]\) 内的数加一,可以记录懒惰标记。

线段树上二分找到端点或直接 FHQ-Treap 分裂出合法区间即可。

代码

#include<bits/stdc++.h> 
#define ll long long
#define ull unsigned long long
#define sort stable_sort
#define endl '\n'
using namespace std;
int ans[300010],l[300010],r[300010];
struct BST
{int root,rt_sum=0;struct FHQ_Treap{int son[2],val,id,rnd,cnt,siz,lazy;}tree[300010];#define lson(rt) (tree[rt].son[0])#define rson(rt) (tree[rt].son[1])BST(){rt_sum=0;srand(time(0));}int build_rt(int val,int id){rt_sum++;lson(rt_sum)=rson(rt_sum)=tree[rt_sum].lazy=0;tree[rt_sum].val=val;tree[rt_sum].id=id;tree[rt_sum].rnd=rand();tree[rt_sum].cnt=tree[rt_sum].siz=1;return rt_sum;}void pushup(int rt){tree[rt].siz=tree[lson(rt)].siz+tree[rson(rt)].siz+tree[rt].cnt;}void pushlazy(int rt,int lazy){tree[rt].lazy+=lazy;tree[rt].val+=lazy;}void pushdown(int rt){pushlazy(lson(rt),tree[rt].lazy);pushlazy(rson(rt),tree[rt].lazy);tree[rt].lazy=0;}void split(int rt,int val,int &x,int &y){if(rt==0) {x=y=0;return;}pushdown(rt);if(tree[rt].val<=val){x=rt;split(rson(rt),val,rson(x),y);}else{y=rt;split(lson(rt),val,x,lson(y));}pushup(rt);}int merge(int rt1,int rt2){if(rt1==0||rt2==0)  return rt1+rt2;pushdown(rt1);pushdown(rt2);if(tree[rt1].rnd<tree[rt2].rnd){rson(rt1)=merge(rson(rt1),rt2);pushup(rt1);return rt1;}else{lson(rt2)=merge(rt1,lson(rt2));pushup(rt2);return rt2;}}void insert(int val,int id){int x,y;split(root,val,x,y);root=merge(merge(x,build_rt(val,id)),y);}void update(int l,int r){int x,y,rt;split(root,r,x,y);split(x,l-1,x,rt);pushlazy(rt,1);root=merge(merge(x,rt),y);}void dfs(int rt){if(rt==0)  return;pushdown(rt);ans[tree[rt].id]=tree[rt].val;dfs(lson(rt));dfs(rson(rt));}
}T;
int main()
{int n,m,x,i;cin>>n;for(i=1;i<=n;i++)  cin>>l[i]>>r[i];cin>>m;for(i=1;i<=m;i++){cin>>x;T.insert(x,i);}for(i=1;i<=n;i++)  T.update(l[i],r[i]);T.dfs(T.root);for(i=1;i<=m;i++)  cout<<ans[i]<<endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/871623.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【pywinauto 库】启动PC端应用程序 - 上篇

一、简介 经过上一篇的学习、介绍和了解,想必小伙伴或者童鞋们,已经见识到pywinauto的强大了,今天继续介绍pywinauto,上一篇已经可以打开计算器了,这里宏哥再提供其他方法进行打开计算器和非电脑自带程序。pywinauto 可以启动电脑自带的应用程序,也可以启动电脑安装的应用…

【反EDR 】概要

一、什么是 EDR EDR 是“端点检测和响应”的缩写。它是部署在每台机器上的代理,用于观察操作系统生成的事件以识别攻击。如果检测到某些东西,它将生成警报并将其发送到 SIEM 或 SOAR,由人工分析师进行查看。“响应”是指在识别威胁后执行的操作,例如隔离主机,这不是本文的…

USB接口颜色都代表什么含义

手机充电器人人都有!充电器线颜色都不同!你知道不同颜色的USB接口的各个颜色都代表什么含义吗?大部分人都是不知道的,这篇文章让您 一目了然!建议收藏备用!以备不时之需!

Windows资源管理器Icon图标注入

免责声明 本文发布的工具和脚本,仅用作测试和学习研究,禁止用于商业用途,不能保证其合法性,准确性,完整性和有效性,请根据情况自行判断。简介 使用图标将 DLL 注入资源管理器的非正统和隐蔽方式 IconJector 这是一个Windows资源管理器DLL注入技术,使用Windows上的更改图…

ElasticSearch Query DSL(查询领域特定语言)

目录常用 DSL 关键字查询上下文相关度评分:_score源数据:_source数据源过滤器query 和 filter 上下文相关性评分 (relevance scores)query 的上下文filter 的上下文关于 query 和 filter 上下文的例子全文查询 (full text query)intervals 查询请求示例intervals的顶级参数ma…

ESP32 学习笔记(九)舵机实验

概念 舵机是一种位置(角度)伺服的驱动器,适用于那些需要角度不断变化并可以保持的控制系统。舵机只是一种通俗的叫法,其本质是一个伺服电机。 舵机有很多规格,但所有的舵机都有外接三根线,分别用棕、红、橙三种颜色进行区分,由于舵机品牌不同,颜色也会有所差异,棕色为…

(原创)[开源][.Net Standard 2.0] SimpleMMF (进程间通信框架)更新 v1.1,极低CPU占用

一、前言 在上一篇 (原创)[.Net] 进程间通信框架(基于共享内存)——SimpleMMF 中,发布了v1.0版,最大的问题是:CPU占用较高,至少40-50%。 这既与我的开发水平有关,也与SimpleMMF诞生环境有关,这个主要是用在数字孪生各软件之间同步数据,而部署软件的工作站性能都强悍…

Elasticsearch 笔记

目录ES 相关概念概述核心概念1)索引 index2)类型 type3) 字段 Filed4)映射 mapping5)文档 document6)集群 cluster7)节点 node8)分片和复制 shards & replicasDocker 中安装 ElasticSearch下载 ElasticSearch 和 Kibana配置启动 ElasticSearch单节点多节点启动开启 …

VMware Avi Load Balancer 31.1.1 发布 - 多云负载均衡平台

VMware Avi Load Balancer 31.1.1 发布 - 多云负载均衡平台VMware Avi Load Balancer 31.1.1 发布 - 多云负载均衡平台 应用交付:多云负载均衡、Web 应用防火墙和容器 Ingress 服务 请访问原文链接:https://sysin.org/blog/vmware-avi-load-balancer-31/ 查看最新版。原创作品…

Angular 中依赖注入问题造成 Observable 订阅不更新

这是园子博客后台从 angular 15 升级到 angular 19 后遇到的一个问题。博客后台「随笔 」的侧边栏会显示随笔的分类列表 ,通过这个列表的上下文菜单可以修改分类名称,升级后测试时发现一个问题,修改分类名称后分类列表没有随之更新这是园子博客后台从 angular 15 升级到 ang…

极紫外光刻掩模上三维图案的严格模拟(下)

1D线掩模:全3D计算域 首先,使用包含吸收体结构和多层反射镜的3D计算域重新审视EUV线掩模。图5显示了对几何体进行离散化的网格(使用网格生成器JCMgeo自动生成)。对于三维设置,网格由棱柱形元素组成(而不是二维设置中的三角形元素)。使用不同的空间网格对相同的物理设置进…

极紫外光刻掩模上三维图案的严格模拟(上)

对具有二维周期性吸收体图案的极紫外光刻掩模的光散射进行了模拟。在一项详细的收敛研究中,表明在相对较大的3D计算域以及存在侧壁角度和拐角圆角的情况下,可以获得准确的结果。 材料和参数设置 所研究的结构由多层反射镜上的吸收器堆叠组成(共120层)。图1显示了几何形状的…