当前位置: 首页 > news >正文

不平均的分治——根号分治

根号分治

如果有一道题:
一个长度为 n n n 的序列 a a a,有 m m m 次操作,对序列某个元素或者某种意义上的区间进行查询(比如:余数为 p p p 的数之和)。
1 ≤ n , m ≤ 1 0 5 1\le n,m\le 10^5 1n,m105
1 ≤ a i , p ≤ 1 0 5 1\le a_i,p\le 10^5 1ai,p105
对于这种操作,直接暴力的复杂度是 O ( N ) O(N) O(N),显然是不可取的。
那我们考虑预处理?用数组存无论的空间还是时间也显然无法操作。
这时候可以考虑一种两者兼备的思路:用数组存空间时间都能接受的部分,剩下的部分暴力。
这就是根号分治。
接下来用一道板子题来详细讲。

例题1

洛谷 - P3396 哈希冲突
先看暴力的做法。

#include<bits/stdc++.h>
#define int long long
#define endl putchar('\n')
using namespace std;
const int N=1e6+5;
int read(){int x=0,f=1;char c=getchar();while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}while(c>='0'&&c<='9')x=(x<<3)+(x<<1)+c-'0',c=getchar();return x*f;
}
void print(int x){if(x<0)putchar('-'),x=-x;if(x<10){putchar(x+'0');return;}print(x/10);putchar(x%10+'0');
}
int n,m;
int a[N];
signed main(){cin>>n>>m;for(int i=1;i<=n;i++)cin>>a[i];while(m--){char op;cin>>op;int x,y;cin>>x>>y;if(op=='A'){int ans=0;for(int i=y;i<=n;i+=x)ans+=a[i];print(ans);endl;}else{a[x]=y;}}
}

上面说过,预处理的部分是空间且时间都能接受的部分,那么我们自然是能预处理多少就尽量预处理,均摊后面 m m m 次操作的时间。
n n n 最大是 1.5 × 1 0 5 1.5\times10^5 1.5×105 n log ⁡ n n\log n nlogn 就显得有些不尊重这个数据了,我们最大可以预处理 O ( N N ) O(N\sqrt N) O(NN )

我们用一个数组 m o d mod mod 存在 n \sqrt n n 的范围内的 p p p m o d i , j mod_{i,j} modi,j 表示下标对 i i i 取余为 j j j 的元素之和。那么为什么在 n \sqrt n n 以上的模数都不用数组存?因为存不下了,因为对于大于 n \sqrt n n 的模数,对应的下标更分散,暴力的时间复杂度在可接受范围内。

#include<bits/stdc++.h>
#define endl putchar('\n')
using namespace std;
const int N=1e6+5;
const int M=1e3+5;
int read(){int x=0,f=1;char c=getchar();while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}while(c>='0'&&c<='9')x=(x<<3)+(x<<1)+c-'0',c=getchar();return x*f;
}
void print(int x){if(x<0)putchar('-'),x=-x;if(x<10){putchar(x+'0');return;}print(x/10);putchar(x%10+'0');
}
int n,m;
int a[N];
int mod[M][M];
signed main(){cin>>n>>m;int len=sqrt(n);for(int i=1;i<=n;i++)a[i]=read();for(int i=1;i<=len;i++){for(int j=1;j<=n;j++){mod[i][j%i]+=a[j];}}while(m--){char op;int x,y;cin>>op>>x>>y;if(op=='A'){if(x<=len){print(mod[x][y]),endl;}else{int res=0;for(int i=y;i<=n;i+=x)res+=a[i];print(res),endl;}}else{for(int i=1;i<=len;i++)mod[i][x%i]-=a[x];a[x]=y;for(int i=1;i<=len;i++)mod[i][x%i]+=a[x];}}
}
http://www.dtcms.com/a/524652.html

相关文章:

  • USP-(DeepSpeed-Ulysses-Attention and Ring-Attention)
  • Ubuntu部署集群环境(3台)
  • VoCo-LLaMA: Towards Vision Compression with Large Language Models 译读笔记
  • 国网北京电力建设研究院网站惠州网站建设电话
  • 鹤壁市住房和城乡建设局网站上线了建站教程
  • centos8.5运行ai00-server报错`GLIBC_2.39‘ not found,解决方法
  • 冷换仓的隐性代价:从安全策略到地址信誉体系的重新思考
  • 如何用Vue CLI 创建 Vue 项目
  • 网站开发专业前景完整php网站开发
  • 企业建网站110平米三室一厅简装图片
  • CAS汽车固件签名:从“完成签名”到“安全治理”的演进之路
  • 免费手机网站模板sem竞价推广怎么做
  • 企业数字化转型的关键一步:打通研发全流程
  • Unity 资源导出的问题,依赖关系过多。
  • 网站开发公司内部数据字典深圳网站建设设计公司
  • 网站建设维护公司地址如何做好网站内容
  • STM32_bug总结-运行函数在SystemInit之后就卡死
  • 基于高光谱成像技术的烟叶含水率检测研究进展
  • 聊城网站推广网站可以换域名吗
  • 一个网站 两个域名淄博公司网站建设价格
  • VBA数据结构终极对决:性能实测与行业应用指南
  • 解码Linux文件IO之JPEG图像原理与应用
  • “短小精悍”的边缘AI算力利器:超微SYS-E403-14B-FRN2T服务器评测
  • Gradio全解14——使用Gradio构建MCP的服务器与客户端(4)——Python包命令:uv与uvx实战
  • php是网站开发的语言吗怎么做好市场宣传和推广
  • 做cms网站步骤广东手机网站建设哪家好
  • GreatSQL 配置 SSL 访问:单机与 MGR 集群指南
  • 网站开发进度把握网站备案需要拍照
  • LC104 二叉树的最大深度
  • 如何构建企业级数据分析助手:Data Agent 开发实践