题意

给你一段长度为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 ;
}

最新文章

  1. putty可以远程连接linux,但上不了网(nat模式)
  2. ios CGRect
  3. iOS设备的越狱方法
  4. Scalaz(12)- Monad:再述述flatMap,顺便了解MonadPlus
  5. ILNumerics项目的应用之线性方程
  6. [POJ 3370] Halloween treats
  7. 大话string
  8. simplest_dll 最简dll的创建与隐式调用(显式调用太麻烦,个人不建议使用)
  9. XML 反序列化为Model
  10. UWP 手绘视频创作工具技术分享系列 - 手绘视频导出
  11. 【python】字符串变量赋值时字符串可用单或双引号
  12. JVM回收方法区内存
  13. CentOS7升级默认内核
  14. IM群聊消息究竟是存1份(即扩散读)还是存多份(即扩散写)?
  15. 关于@RestController注解(转发)
  16. 一个讲课截屏 清明DAY2
  17. iptables做端口转发
  18. e614. Setting the Initial Focused Component in a Window
  19. 【.netcore学习】.netcore添加到 supervisor 守护进程自启动报错
  20. ionic4 ios调试打包

热门文章

  1. 深入理解Jvm--Java静态分配和动态分配完全解析
  2. linux 使用 ioctl 参数
  3. js中的函数重载
  4. 2019-4-29-C#-从-short-转-byte-方法
  5. webpack4.0基本配置,超简单!
  6. dotnet 如何在 Mock 模拟 Func 判断调用次数
  7. 微软软件开发技术二十年回顾-.NET框架篇
  8. 使用Git和Github来管理自己的代码和笔记
  9. QString 转换为 char *
  10. com.mysql.jdbc.PacketTooBigException: Packet for query is too large (1680 &gt; 1024). You can change this value on the server by setting the max_allowed_packet&#39; variable.