二维数点 系列 题解

1.AT_dp_w Intervals

我的博客

2.CF377D Developing Games

我的博客

这两道题是比较经典的线段树区间 trick,希望自己可以在以后的比赛中手切。

3.洛谷 P10814 离线二维数点

题意

给你一个长为 n n n 的序列 a a a,有 m m m 次询问,每次询问给定 l , r , x l,r,x l,r,x,求 [ l , r ] [l,r] [l,r] 区间中小于等于 x x x 的元素个数。

1 ≤ n , m , a i , l , r , x ≤ 2 × 1 0 6 1\le n,m,a_i,l,r,x\le 2\times10^6 1n,m,ai,l,r,x2×106

思路

前缀和思想,用 [ 1 , r ] [1,r] [1,r] 中小于等于 x x x 的数量,减去 [ 1 , l − 1 ] [1,l-1] [1,l1] 中小于等于 x x x 的数量,就可以了。

考虑枚举条件端点,从而改变权值。

用线段树常数比较大,在洛谷 TLE 最后一个点,还是用树状数组吧,反正也比较方便。

代码

#include<bits/stdc++.h>
using namespace std;
#define ll long long
inline ll read()
{ll s=0,w=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();return s*w;
}
inline void write(ll x)
{ if(x==0){putchar('0');return;}ll len=0,k1=x,c[10005];if(k1<0)k1=-k1,putchar('-');while(k1)c[len++]=k1%10+'0',k1/=10;while(len--)putchar(c[len]);
}
#define ls u<<1
#define rs u<<1|1
const ll N=2e6+9;
ll n,m,a[N];
ll M,ans[N];
struct term
{ll d,id,v;
};
vector<term>p[N];
struct BT
{ll T[N];ll lowbit(ll x){return x&(-x);}void add(ll x,ll k){for(int i=x;i<=M;i+=lowbit(i))T[i]+=k;}ll query(ll x){ll ret=0;for(int i=x;i>=1;i-=lowbit(i))ret+=T[i];return ret;}
}B;
int main()
{n=read(),m=read();for(int i=1;i<=n;i++){a[i]=read();M=max(M,a[i]);}for(int i=1;i<=m;i++){ll l,r,d;l=read(),r=read(),d=read();p[l-1].push_back((term){d,i,-1});p[r].push_back((term){d,i,1});M=max(M,d);}for(int i=1;i<=n;i++){B.add(a[i],1);for(auto x:p[i])ans[x.id]+=x.v*B.query(x.d);}for(int i=1;i<=m;i++)write(ans[i]),puts("");return 0;
}

4.洛谷 P1972 SDOI2009 HH的项链

给定一个序列 a i a_i ai m m m 次询问区间 [ l , r ] [l,r] [l,r] 中有多少种不同的数。

1 ≤ n , m , ∀ a i ≤ 1 0 6 1\le n,m,\forall a_i\le 10^6 1n,m,ai106 1 ≤ l ≤ r ≤ n 1\le l\le r\le n 1lrn

思路

一眼想用莫队,但是 Θ ( n n ) \Theta(n\sqrt{n}) Θ(nn ),令人畏惧(在古早时期学莫队的时候卡常过了),那么分块也并非正解了。

区间内有不同的数,那么多次出现的只算做一个。这题还是查询区间,那么能不能用二维数点来做呢?

设序列中 a i a_i ai 上一次出现在下标 p r e i pre_i prei,没有则 p r e i = 0 pre_i=0 prei=0,如果一个数在下标区间 [ l , r ] [l,r] [l,r] 中首次出现,那么 p o s i < l pos_i<l posi<l;如果出现第二次,那么必然 p r e i ∈ [ l , r ] pre_i\in[l,r] prei[l,r]

那么题目就转化成了,求区间 [ l , r ] [l,r] [l,r] 中,有多少个 p r e i < l pre_i<l prei<l

那不就和上一题一样了吗?同样使用前缀和思想,枚举右端点。

不过这一题有 0 0 0 出现,扔上树状数组会出问题,所以记得加 1 1 1

代码

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const ll N=1e6+9;
ll n,m,a[N];
ll pre[N],pos[N];
ll ans[N];
struct que
{ll l,r,id;
}q[N];
bool cmp(que x,que y)
{if(x.l!=y.l)return x.l<y.l;return x.r<y.r;
}
struct term
{ll d,id,v;
};
vector<term>p[N];
struct BT
{ll T[N];ll lowbit(ll x){return x&(-x);}void add(ll x,ll k){for(int i=x;i<=n;i+=lowbit(i))T[i]+=k;}ll query(ll x){ll ret=0;for(int i=x;i>=1;i-=lowbit(i))ret+=T[i];return ret;}
}B;
int main()
{scanf("%lld",&n);for(int i=1;i<=n;i++){scanf("%lld",&a[i]);pre[i]=pos[a[i]];pos[a[i]]=i;}scanf("%lld",&m);for(int i=1;i<=m;i++){ll l,r;scanf("%lld%lld",&l,&r);q[i]=(que){l,r,i};p[l-1].push_back((term){l-1,i,-1});p[r].push_back((term){l-1,i,1});}sort(q+1,q+m+1,cmp);//答案就是[l,r]中pre(i)<l的个数 for(int i=1;i<=n;i++){B.add(pre[i]+1,1);for(auto x:p[i])ans[x.id]+=x.v*B.query(x.d+1);}for(int i=1;i<=m;i++)printf("%lld\n",ans[i]);return 0;
}

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

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

相关文章

vulkanscenegraph显示倾斜模型(5.9)-vsg中vulkan资源的编译

前言 上一章深入剖析了GPU资源内存及其管理&#xff0c;vsg中为了提高设备内存的利用率&#xff0c;同时减少内存(GPU)碎片&#xff0c;采用GPU资源内存池机制(vsg::MemoryBufferPools)管理逻辑缓存(VkBuffer)与物理内存(VkDeviceMemory)。本章将深入vsg中vulkan资源的编译(包含…

探秘 Python 网络编程:构建简单聊天服务器

在计算机网络的世界里&#xff0c;网络编程是实现不同设备之间通信的关键技术。Python 凭借其简洁的语法和强大的库支持&#xff0c;在网络编程领域有着广泛的应用。无论是构建简单的聊天服务器&#xff0c;还是开发复杂的网络应用&#xff0c;Python 都能轻松胜任。 1 理论基础…

Go语言Slice切片底层

Go语言&#xff08;Golang&#xff09;中切片&#xff08;slice&#xff09;的相关知识、包括切片与数组的关系、底层结构、扩容机制、以及切片在函数传递、截取、增删元素、拷贝等操作中的特性。并给出了相关代码示例和一道面试题。关键要点包括&#xff1a; 数组特性&#xf…

vue3 ts 自定义指令 app.directive

在 Vue 3 中&#xff0c;app.directive 是一个全局 API&#xff0c;用于注册或获取全局自定义指令。以下是关于 app.directive 的详细说明和使用方法 app.directive 用于定义全局指令&#xff0c;这些指令可以用于直接操作 DOM 元素。自定义指令在 Vue 3 中非常强大&#xff0…

基于python的机器学习(五)—— 聚类(二)

一、k-medoids聚类算法 k-medoids是一种聚类算法&#xff0c;它是基于k-means聚类算法的一种改进。k-medoids算法也是一种迭代算法&#xff0c;但是它将中心点限定为数据集中的实际样本点&#xff0c;而不是任意的点。 具体来说&#xff0c;k-medoids算法从数据集中选择k个初…

解释:指数加权移动平均(EWMA)

指数加权移动平均&#xff08;EWMA, Exponential Weighted Moving Average&#xff09; 是一种常用于时间序列平滑、异常检测、过程控制等领域的统计方法。相比普通移动平均&#xff0c;它对最近的数据赋予更高权重&#xff0c;对旧数据逐渐“淡化”。 ✅ 一、通俗理解 想象你…

Spring Boot 项目基于责任链模式实现复杂接口的解耦和动态编排!

全文目录&#xff1a; 开篇语前言一、责任链模式概述责任链模式的组成部分&#xff1a; 二、责任链模式的核心优势三、使用责任链模式解耦复杂接口1. 定义 Handler 接口2. 实现具体的 Handler3. 创建订单对象4. 在 Spring Boot 中使用责任链模式5. 配置责任链6. 客户端调用 四、…

COMSOL仿真遇到的两个小问题

最近跑热仿真的时候跑出了两个问题&#xff0c;上网查发现也没什么解决方式&#xff0c;最后自己误打误撞的摸索着解决了&#xff0c;在这里分享一下。 问题一 我当时一准备跑仿真就弹出了这个东西&#xff0c;但在此之前从未遇到 然后我试着在它说的路径中建立recoveries文件…

如何在英文学术写作中正确使用标点符号?

标点符号看似微不足道&#xff0c;但它们是书面语言的无名英雄。就像熟练的指挥家指挥管弦乐队一样&#xff0c;标点符号可以确保您的写作流畅、传达正确的含义并引起读者的共鸣。正如放错位置的音符会在音乐中造成不和谐一样&#xff0c;放错位置的逗号或缺少分号也会使您的写…

【深度学习与大模型基础】第10章-期望、方差和协方差

一、期望 ——————————————————————————————————————————— 1. 期望是什么&#xff1f; 期望&#xff08;Expectation&#xff09;可以理解为“长期的平均值”。比如&#xff1a; 掷骰子&#xff1a;一个6面骰子的点数是1~6&#x…

JAVA虚拟机(JVM)学习

入门 什么是JVM JVM&#xff1a;Java Virtual Machine&#xff0c;Java虚拟机。 JVM是JRE(Java Runtime Environment)的一部分&#xff0c;安装了JRE就相当于安装了JVM&#xff0c;就可以运行Java程序了。JVM的作用&#xff1a;加载并执行Java字节码&#xff08;.class&#…

【数据结构与算法】——堆(补充)

前言 上一篇文章讲解了堆的概念和堆排序&#xff0c;本文是对堆的内容补充 主要包括&#xff1a;堆排序的时间复杂度、TOP 这里写目录标题 前言正文堆排序的时间复杂度TOP-K 正文 堆排序的时间复杂度 前文提到&#xff0c;利用堆的思想完成的堆排序的代码如下&#xff08;包…

什么是柜台债

柜台债&#xff08;柜台债券业务&#xff09;是指通过银行等金融机构的营业网点或电子渠道&#xff0c;为投资者提供债券买卖、托管、结算等服务的业务模式。它允许个人、企业及机构投资者直接参与银行间债券市场的交易&#xff0c;打破了以往仅限机构参与的壁垒。以下是综合多…

【Android读书笔记】读书笔记记录

文章目录 一. Android开发艺术探索1. Activity的生命周期和启动模式1.1 生命周期全面分析 一. Android开发艺术探索 1. Activity的生命周期和启动模式 1.1 生命周期全面分析 onPause和onStop onPause后会快速调用onStop&#xff0c;极端条件下直接调用onResume 当用户打开新…

Java对象内存结构详解

Java对象内存结构详解 Java对象在JVM内存中的存储结构可以分为三个部分&#xff1a;对象头&#xff08;Header&#xff09;、实例数据&#xff08;Instance Data&#xff09;和对齐填充&#xff08;Padding&#xff09;。以下是64位JVM&#xff08;开启压缩指针&#xff09;下…

【TI MSPM0】Printf重定向学习

一、新建工程 通过XDS110与电脑进行通信。 选择这两个引脚 需要添加这两个头文件 在程序中添加这三个函数即可对printf进行重定向 二、封装函数 另一种方法 封装一个函数&#xff0c;定义一个数组

深度强化学习基础 0:通用学习方法

过去自己学习深度强化学习的痛点&#xff1a; 只能看到各种术语、数学公式勉强看懂&#xff0c;没有建立清晰且准确关联 多变量交互关系浮于表面&#xff0c;有时候连环境、代理控制的变量都混淆 模型种类繁多&#xff0c;概念繁杂难整合、对比或复用&#xff0c;无框架分析所…

asm汇编源代码之-字库转换程序

将标准的16x16点阵汉字库(下载16x16汉字库)转换成适合VGA文本模式下显示的点阵汉字库 本程序需要调用file.asm中的子程序,所以连接时需要把file连接进来,如下 C:\> tlink chghzk file 调用参数描述如下 C:\> chghzk ; 无调用参数,转换标准库文件(SRC16.FNT)为适合VGA…

uniapp转换markdown

效果 AI智能体 微信小程序 流式 1.安装Node.js 参考:2024最新版Node.js下载安装及环境配置教程&#xff08;非常详细&#xff09;_node.js 安装-CSDN博客 2.需要克隆项目到本地或直接到项目地址下载压缩包。 参考&#xff1a;uniapp中解析markdown支持网页和小程序_uniapp ma…

用java代码如何存取数据库的blob字段

一.业务 在业务中我们被要求将文件或图片等转成 byte[] 或 InputStream存到数据库的Blob类型的字段中. 二.Blob类型介绍 在 MySQL 中&#xff0c;Blob 数据类型用于存储二进制数据。MySQL 提供了四种不同的 Blob 类型&#xff1a; TINYBLOB: 最大存储长度为 255 个字节。BL…