题目链接

大数除法是很麻烦的,考虑能不能将其条件化简

一段区间[l,r]|p,即num[l,r]|p,类似前缀,记后缀suf[i]表示[i,n]的这段区间代表的数字

于是有 suf[l]-suf[r+1]|p -> (suf[l]-suf[r+1])%p = 0 -> suf[l] ≡suf[r+1] (mod p)

即若suf[r+1]%p = suf[l]%p,则num[l,r]|p

于是我们可以把范围控制在p以内,查找是否有%p相等的区间 -> 莫队

即小Z的袜子

这样的实际意义是 \((suf[l]-suf[r+1])*10^{n-r}%p = 0\)

后面有个10的幂,如果n-r>0 对于p(p|10)显然无论[l,r]是什么都会满足条件

于是p=2,5时要换一种判断方式。显然若有一位A[i]满足A[i]|p,则之前的Aj都可以以它为结尾并对答案做出贡献

若数列(都加l-1)a,b,c,d,e中,A[a,d,e]|p,则答案为e+d+a-3*(l-1)

这个在线做就可以了 (另外有人知道这个我莫队为什么不对吗。。)

另外要注意p范围不定,要对出现的余数离散化

然后参数p和模数p会重着 要注意!

要注意会有A[n+1],离散化要注意这个变量默认0!

另外p<P时特判为什么不对。。

洛谷数据真的水。。在BZOJ被longlong什么的各种坑。

#include <cmath>
#include <cctype>
#include <cstdio>
#include <algorithm>
#define gc() getchar()
typedef long long LL;
const int N=2e5+5,P=1e6; int n,m,size,tm[P+5],Cnt;
LL p/*LL!*/,A[N],suf[N],ref[N],Now,Ans[N],sum[N],num[N];
struct Ask
{
int l,r,id;
bool operator <(const Ask &a)const {
return l/size==a.l/size?r<a.r:l/size<a.l/size;
}
}q[N]; inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
}
inline void Update(int pos,int delta){
if(!(A[pos]%p)) Now+=delta*pos, Cnt+=delta;
}
void Spec()
{
for(int i=1; i<=n; ++i)
if(A[i]%p) sum[i]=sum[i-1],num[i]=num[i-1];
else sum[i]=sum[i-1]+i,num[i]=num[i-1]+1;
for(LL l,r,i=1; i<=m; ++i)
l=read(),r=read(), printf("%lld\n",sum[r]-sum[l-1]-(num[r]-num[l-1])*(l-1));
// for(int l=1,r=0,i=1; i<=m; ++i)
// {
// while(l<q[i].l) Update(l,-1),++l;
// while(l>q[i].l) --l,Update(l,1);
// while(r<q[i].r) ++r,Update(r,1);
// while(r>q[i].r) Update(r,-1),--r;
// Ans[q[i].id]=Now-Cnt*(q[i].l-1);
// }
}
inline void Add(int p){
if(!p) return;
Now+=tm[p], ++tm[p];
// if(++tm[p]>1) Now+=tm[p]-1;//不要判什么tm[]>1之类满足才更新答案,因为tm[]在中间过程是可以存在负数的
}
inline void Subd(int p){
if(!p) return;
--tm[p], Now-=tm[p];
// if(--tm[p]) Now-=tm[p];//这一写法效果一样(因为只判了!=0) 但不能这么写
}
void Normal()
{
for(int l=1,r=0,i=1; i<=m; ++i)
{
while(l<q[i].l) Subd(suf[l++]);
while(l>q[i].l) Add(suf[--l]);
while(r<q[i].r) Add(suf[++r]);
while(r>q[i].r) Subd(suf[r--]);
Ans[q[i].id]=Now;
}
}
int Find(int x,int r)
{
int l=1,mid;
while(l<r)
if(ref[mid=l+r>>1]>=x) r=mid;
else l=mid+1;
return l;
}
void Discrete()
{
for(int i=1; i<=n; ++i) ref[i]=suf[i];
std::sort(ref+1,ref+1+n);
int cnt=1;
for(int i=2; i<=n; ++i)
if(ref[i]!=ref[i-1]) ref[++cnt]=ref[i];
for(int i=1; i<=n; ++i) suf[i]=Find(suf[i],cnt);
suf[n+1]=ref[1]?0:1;
} int main()
{
scanf("%lld",&p);
char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);A[++n]=c-'0',c=gc());
m=read(), size=sqrt(n);
if(p==2||p==5) {Spec(); return 0;}
for(int i=1; i<=m; ++i)
q[i].l=read(),q[i].r=read()+1,q[i].id=i;//q:r+1
LL pw10=1;//longlong!
for(int i=n; i; --i)
suf[i]=(A[i]*pw10%p+suf[i+1])%p, pw10=pw10*10%p;
// if(p>P) Discrete();//这个if?
Discrete();
std::sort(q+1,q+1+m);
// if(p==2||p==5) Spec();
// else Normal();
Normal();
for(int i=1; i<=m; ++i) printf("%lld\n",Ans[i]); return 0;
}

BZOJ.4542.[HNOI2016]大数(莫队)的更多相关文章

  1. bzoj 4542: [Hnoi2016]大数 (莫队)

    Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345.小B还有一个素数P.现在,小 B 提出了 M 个询问,每个 ...

  2. 【BZOJ4542】[Hnoi2016]大数 莫队

    [BZOJ4542][Hnoi2016]大数 Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345.小B还有一个 ...

  3. BZOj 4540: [Hnoi2016]序列 [莫队 st表 预处理]

    4540: [Hnoi2016]序列 题意:询问区间所有子串的最小值的和 不强制在线当然上莫队啦 但是没想出来,因为不知道该维护当前区间的什么信息,维护前后缀最小值的话不好做 想到单调栈求一下,但是对 ...

  4. [BZOJ4542] [Hnoi2016] 大数 (莫队)

    Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345.小B还有一个素数P.现在,小 B 提出了 M 个询问,每个 ...

  5. BZOJ.4540.[HNOI2016]序列(莫队/前缀和/线段树 单调栈 RMQ)

    BZOJ 洛谷 ST表的一二维顺序一定要改过来. 改了就rank1了哈哈哈哈.自带小常数没办法. \(Description\) 给定长为\(n\)的序列\(A_i\).\(q\)次询问,每次给定\( ...

  6. BZOJ 4540 [Hnoi2016]序列 | 莫队 详细题解

    传送门 BZOJ 4540 题解 --怎么说呢--本来想写线段树+矩阵乘法的-- --但是嘛--yali的机房太热了--困--写不出来-- 于是弃疗,写起了莫队.(但是我连莫队都想不出来!) 首先用单 ...

  7. bzoj4542 [Hnoi2016]大数 莫队+同余

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4542 题解 我们令 \(f_i\) 表示从 \(i\) 到 \(n\) 位组成的数 \(\bm ...

  8. bzoj 4542: [Hnoi2016]大数

    Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345 小B还有一个素数P.现在,小 B 提出了 M 个询问,每个 ...

  9. 洛谷P3245 [HNOI2016]大数(莫队)

    题意 题目链接 Sol 莫队板子题.. 维护出每个位置开始的字符串\(mod P\)的结果,记为\(S_i\) 两个位置\(l, r\)满足条件当且仅当\(S_l - S_r = 0\),也就是\(S ...

随机推荐

  1. Java探针-Java Agent技术-阿里面试题

    Java探针参考:Java探针技术在应用安全领域的新突破 最近面试阿里,面试官先是问我类加载的流程,然后问了个问题,能否在加载类的时候,对字节码进行修改 我懵逼了,答曰不知道,面试官说可以的,使用Ja ...

  2. Pytorch入门之VAE

    关于自编码器的原理见另一篇博客 : 编码器AE & VAE 这里谈谈对于变分自编码器(Variational auto-encoder)即VAE的实现. 1. 稀疏编码 首先介绍一下“稀疏编码 ...

  3. 二、Linear Regression 练习(转载)

    转载链接:http://www.cnblogs.com/tornadomeet/archive/2013/03/15/2961660.html 前言 本文是多元线性回归的练习,这里练习的是最简单的二元 ...

  4. Linux内存管理6---伙伴算法与slab

    1.前言 本文所述关于内存管理的系列文章主要是对陈莉君老师所讲述的内存管理知识讲座的整理. 本讲座主要分三个主题展开对内存管理进行讲解:内存管理的硬件基础.虚拟地址空间的管理.物理地址空间的管理. 本 ...

  5. 解决Myeclipse启动Spring Boot项目报出莫名异常

    有时候明明代码.配置都是正确的,但是一启动却报出莫名其妙的异常. 主要原因是resource包下的xml.yml文件或者其他配置文件路径不正确,解决方法如下: 第一步. 第二步.如果Excluded不 ...

  6. PYTHON-匿名函数,递归与二分法,面向过程编程-练习

    # 四 声明式编程练习题 # 1.将names=['egon','alex_sb','wupeiqi','yuanhao']中的名字全部变大写names = ['egon', 'alex_sb', ' ...

  7. [Android四大组件之二]——Service

    Service是Android中四大组件之一,在Android开发中起到非常重要的作用,它运行在后台,不与用户进行交互. 1.Service的继承关系: java.lang.Object → andr ...

  8. oracle进阶之connect by笔记

    本博客是自己在学习和工作途中的积累与总结,仅供自己参考,也欢迎大家转载,转载时请注明出处. http://www.cnblogs.com/king-xg/p/6794562.html 如果觉得对您有帮 ...

  9. OCM_第十三天课程:Section6 —》数据库性能调优 _结果缓存 /多列数据信息采集统计/采集数据信息保持游标有效

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  10. 性能测试五:jmeter进阶之后置处理器(正则、json提取器)

    如,从get返回的json中提取stock的值 作为post的请求参数 1.JSON提取器 专门对json数据进行提取的后置处理器 Debug Sampler:记录之前的请求的所有参数及数据 2.正则 ...