LGP9607 [CERC 2019] Be Geeks! 学习笔记

news/2025/2/22 23:03:19/文章来源:https://www.cnblogs.com/OrinLoong/p/18719143

LGP9607 [CERC 2019] Be Geeks! 学习笔记

Luogu Link

题意简述

给定一个长为 \(n\) 的序列 \(A\)
定义 \(G(l,r)=\gcd(a_l,a_{l+1}\cdots a_r)\)
定义 \(M(l,r)=\max(a_l,a_{l+1}\cdots a_r)\)
定义 \(P(l,r)=G(l,r)\times M(l,r)\)
计算 \(\sum P(i,j)[1\le i\le j\le N]\)

\(N\le 2\times10^5\)

做法解析

看到这种静态计算 \(\sum F(i,j)[1\le i\le j\le N]\),其中 \(F\) 是某个有关于 \(\max\)\(\min\) 的函数的,就想到“极值分治”。这种思想利用每个元素作为极值的区间的包含关系,建立一棵笛卡尔树做到不重不漏。考虑建笛卡尔树。

考虑我们遍历到笛卡尔树的 \(u\) 结点时,我们将考虑所有横跨 \(u\) 的区间,它们的 \(\max\) 都已经确定下来了,但是 \(\gcd\) 呢?一个经典结论是:一个序列的所有前缀的 \(\gcd\) 只有 \(O(\log V)\) 种取值(考虑一个缀变长时其 \(\gcd\) 不可能变大,若变小则至少减小一半,最多减小 \(\log V\) 次),后缀同理。又由于我们当前枚举的区间总是由 \([cl,u]\) 的一个后缀和 \([u,cr]\) 的一个前缀构成,所以 \(\gcd\) 的取值最多有 \(O(\log^2 V)\) 种。并且由于 \(\gcd\) 随着缀扩大而单调不增,所以我们可以每次用一个 \(O(\log N)\) 的二分确定 \(\gcd(x,u)\)(或 \(\gcd(u,x)\))取值相同的一段。总的时间复杂度就是 \(\max(O(N\log N\log V),O(N\log^2 V))\)

pEKXPgS.md.png

代码实现

#include <bits/stdc++.h>
using namespace std;
namespace obasic{typedef long long lolo;template <typename _T>void readi(_T &x){_T k=1;x=0;char ch=getchar();for(;!isdigit(ch);ch=getchar())if(ch=='-')k=-1;for(;isdigit(ch);ch=getchar())x=(x<<3)+(x<<1)+ch-'0';x*=k;return;}template <typename _T>void writi(_T x){if(x<0)putchar('-'),x=-x;if(x>9)writi(x/10);putchar(x%10+'0');}
};
using namespace obasic;
const int MaxN=2e5+5,Mod=1e9+7;
int N,A[MaxN],lg2[MaxN],cd[20][MaxN];
int stk[MaxN],ktp,ls[MaxN],rs[MaxN];
void st_prework(){for(int i=1;i<=N;i++)cd[0][i]=A[i];for(int i=1,w;(w=1<<i)<=N;i++){for(int j=1;j+w-1<=N;j++){cd[i][j]=gcd(cd[i-1][j],cd[i-1][j+(w>>1)]);}}
}
int getgcd(int l,int r){int k=lg2[(r-l+1)];return gcd(cd[k][l],cd[k][r-(1<<k)+1]);
}
int getj(int t,int u,int bl,int br,int val){int bmid,res=u;while(bl<=br){bmid=(bl+br)>>1;if(!t)getgcd(bmid,u)==val?res=bmid,br=bmid-1:bl=bmid+1;else getgcd(u,bmid)==val?res=bmid,bl=bmid+1:br=bmid-1;}return res;
}
map<int,int> mp1,mp2;
lolo solve(int u,int cl,int cr){lolo res=0;if(cl==cr)return 1ll*A[u]*A[u]%Mod;if(ls[u])(res+=solve(ls[u],cl,u-1))%=Mod;if(rs[u])(res+=solve(rs[u],u+1,cr))%=Mod;for(int i=u,j,ccd;i>=cl;i=j-1)ccd=getgcd(i,u),j=getj(0,u,cl,i,ccd),mp1[ccd]=i-j+1;for(int i=u,j,ccd;i<=cr;i=j+1)ccd=getgcd(u,i),j=getj(1,u,i,cr,ccd),mp2[ccd]=j-i+1;for(auto [xn,xc] : mp1)for(auto [yn,yc] : mp2)(res+=1ll*A[u]*gcd(xn,yn)%Mod*xc%Mod*yc%Mod)%=Mod;mp1.clear(),mp2.clear();return res;
}
lolo ans;
int main(){readi(N);for(int i=1;i<=N;i++)readi(A[i]);for(int i=2;i<=N;i++)lg2[i]=lg2[i>>1]+1;for(int i=1;i<=N;i++){int k=ktp;while(k&&A[stk[k]]<A[i])k--;if(k<ktp)ls[i]=stk[k+1];if(k)rs[stk[k]]=i;stk[++k]=i,ktp=k;}st_prework();ans=solve(stk[1],1,N);writi(ans);return 0;
}

反思总结

全部区间进行静态计算某个关于极值的函数就考虑见笛卡尔树做极值分治。

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

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

相关文章

卷积,toeplitz矩阵与傅里叶变换FT

卷积,toeplitz矩阵与傅里叶变换FT相关与卷积 一维相关和卷积运算是两个向量共同作用得到一个新的向量。 相关的分量形式: \[\begin{aligned} 映射(f: \mathbb{Z} \to \mathbb{R}),对于(w = (w(-a), \ldots, w(0), \ldots, w(a))), \\ 一维相关: g(x) = \sum_{s = -a}^{a}…

记录一次修复 JetBrains Rider 控制台输出乱码

在使用 JetBrains Rider 调试程序时,控制台输出日志出现了乱码。歪打正着结果困扰许久的问题得到了解决,于是记录下了这个小短文。 具体的修复建议如下:将终端编码设置为 GB2312 具体操作:设置->编辑器->常规->控制台->设置为 GB2312 ->保存之前在网上找各…

联合体union

占用大小按字节数最大的变量来,下面的联合体的大小为4字节typedef union MyUnion {char c; //1byteint i; //4byte } _MyUnion; int main() {_MyUnion v;printf("%x, %x\n", v.c, v.i); //未初始化时的值printf("%x, %x, %x, %x\n", &v, &v.c, &a…

使用docker搭建php开发环境

本文年代久远,可能已经不适用。仅供参考! 新的php镜像参考 多容器 apache+php+mariadb+redis主要配置 构建php镜像 基于官方php镜像进行定制,增加所需的php扩展,修改php配置,以及创建虚拟主机。 Dockerfile 文件php/Dockerfile FROM php:apache# php configure COPY php.i…

基于SVPWM矢量控制的无速度传感器电机控制系统simulink建模与仿真

1.课题概述基于SVPWM矢量控制的无速度传感器电机控制系统simulink建模与仿真,包括电机,SVPWM模块,矢量控制器模块等。2.系统仿真结果3.核心程序与模型 版本:MATLAB2022a 4.系统原理简介基于空间电压矢量控制(Space Vector PWM,SVPWM)的无速度传感器电机控制系统,特别是…

如何为 .NET 在线客服系统的 Open Api 开放接口实现 QPS 限流功能

在 .NET 中实现 QPS 限流有很多方案,对于小流量的应用,内存限流和基于中间件的限流方式可能已经足够,而对于高并发的分布式系统,可能需要 Redis 或者更复杂的算法,如令牌桶或滑动窗口。我在业余时间开发了一款自己的独立产品:升讯威在线客服与营销系统。陆陆续续开发了几…

C# 部署 tensorRT resnet分类模型 deploy TensorRT model with C#

基于生态的优势,一般都是用pytorch写模型;但是工业现场的部署,目前比较方便的还是onnx;当下为了追求效率,使用了TensorRT C#: .net8 GPU: A2000 / 4070Ti OS: windows Cuda: 11.8 预处理:Emgu.CVinstall v11.8 Cuda 默认安装,会生成以下路径 C:\Program Files\NVIDIA GP…

自然语言处理入门【第6章】:自然语言处理的应用

搜广推业务 信息检索 搜索、广告和推荐是很多互联网大厂赖以生存的命脉。比如,百度的搜索引擎、京东淘宝的推荐系统、腾讯的广告业务等。这一节我们就看看搜广推业务当中的自然语言处理方法。 1. 什么是信息检索 信息检索(Information Retrieval,IR)是指从大量的非结构化或…

提取东京食尸鬼主题曲

钢琴的声音实在是太好听了,这演奏者的指法真的逆天了! 利用IE缓存来提取视频文件是屡试不爽啊,只要视频不是经过加密的,均能提取成功。打开IE浏览器,关闭所有标签,仅留下一个空白标签,并打开Internet选项删除浏览历史记录点设置,查看文件,打开缓存文件夹,删除文件夹内…

树梅派XBMC解决方案比较

本文是Raspberry Pi XBMC Solutions Compared: Raspbmc vs OpenELEC vs XBian的译文,可能已经过时。XMBC是我们最喜欢的媒体中心解决方案之一。Raspberry Pi使得打造一台豪华的XMBC机器仅需35$。有三个为Pi定制的版本,但是,你该选择哪一个呢?这些版本略有差异,各有长短。本…

deepseek破限的一种方法

起因是https://www.south-plus.net/read.php?tid=2455666这篇帖子的作者在B22F提到他的Deepseek的破甲关键词和使用流程,咱直接复制粘贴直接被deepseek拒绝了呜呜呜 失败案例: 我大致提取了一段不会被办的话,试了一下可以和其他的混合使用破甲效果极佳(但是荤段子得靠其他…

实体机双系统

本文年代久远,可能已经不再适用。仅供参考首先说一下,双系统并不会影响两个系统各自的速度。两个系统都是独立的,分别位于硬盘的不同位置,独立运行。也就是说,当一个系统在运行时,另一个系统只是储存在硬盘上的文件,这自然不会对系统的速度有影响。 另外,安装双系统是有…