(分块暴力)Time to Raid Cowavans CodeForces - 103D
2024-09-05 13:34:37
题意
给你一段长度为n(1 ≤ n ≤ 3·1e5)的序列,m (1 ≤ p ≤ 3·1e5)个询问,每次询问a,a+b,a+2b+...<=n的和
思路
一开始一直想也想不到怎么分,去维护哪些信息,看了题解才知道 其实分块不仅仅可以将一列序列分块,还可以将数据进行分块,下面讨论具体做法
首先这道题不是在线询问,可以离线做,先读入所有的询问,将询问从小到大排序
①当b<√n时,对于每一个b我们可以预处理出这样的一个数组sum[i],就是以i为起点间隔为b的序列和(可以用一个简单的dp求出来),然后O(1)查询,这么做的好处就是如果不同的询问a不同,b相同,经过排序我们就可以直接使用这个sum数组,时间复杂度为O(n√n)。
②当b≥√n时,直接暴力求和,时间复杂度为O(m√n)
所以总时间复杂度为O((m+n)√n)
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
const int maxn=3e5+;
typedef long long ll;
ll a[maxn];
struct node{
int a,b,id;
bool operator<(const node &s) const
{
return b<s.b;
}
}b[maxn];
ll ans[maxn];
ll sum_b[maxn];
int main()
{
int n,m;
scanf("%d",&n);
int bl=sqrt(n);
for(int i=;i<=n;i++)
scanf("%I64d",&a[i]);
scanf("%d",&m);
for(int i=;i<=m;i++){
b[i].id=i;
scanf("%d%d",&b[i].a,&b[i].b);
}
sort(b+,b++m);
b[].b=;
for(int i=;i<=m;i++){
if(b[i].b>=bl){
ans[b[i].id]=;
for(int k=b[i].a;k<=n;k+=b[i].b)
ans[b[i].id]+=a[k];
}
else{
if(b[i].b==b[i-].b){
ans[b[i].id]=sum_b[b[i].a];
}
else{
for(int j=n;j>=;j--)
if(j+b[i].b>n)
sum_b[j]=a[j];
else
sum_b[j]=sum_b[j+b[i].b]+a[j];
ans[b[i].id]=sum_b[b[i].a];
}
}
}
for(int i=;i<=m;i++)
printf("%I64d\n",ans[i]);
return ;
}
最新文章
- putty可以远程连接linux,但上不了网(nat模式)
- ios CGRect
- iOS设备的越狱方法
- Scalaz(12)- Monad:再述述flatMap,顺便了解MonadPlus
- ILNumerics项目的应用之线性方程
- [POJ 3370] Halloween treats
- 大话string
- simplest_dll 最简dll的创建与隐式调用(显式调用太麻烦,个人不建议使用)
- XML 反序列化为Model
- UWP 手绘视频创作工具技术分享系列 - 手绘视频导出
- 【python】字符串变量赋值时字符串可用单或双引号
- JVM回收方法区内存
- CentOS7升级默认内核
- IM群聊消息究竟是存1份(即扩散读)还是存多份(即扩散写)?
- 关于@RestController注解(转发)
- 一个讲课截屏 清明DAY2
- iptables做端口转发
- e614. Setting the Initial Focused Component in a Window
- 【.netcore学习】.netcore添加到 supervisor 守护进程自启动报错
- ionic4 ios调试打包
热门文章
- 深入理解Jvm--Java静态分配和动态分配完全解析
- linux 使用 ioctl 参数
- js中的函数重载
- 2019-4-29-C#-从-short-转-byte-方法
- webpack4.0基本配置,超简单!
- dotnet 如何在 Mock 模拟 Func 判断调用次数
- 微软软件开发技术二十年回顾-.NET框架篇
- 使用Git和Github来管理自己的代码和笔记
- QString 转换为 char *
- com.mysql.jdbc.PacketTooBigException: Packet for query is too large (1680 >; 1024). You can change this value on the server by setting the max_allowed_packet&#39; variable.