【bzoj4542】 Hnoi2016—大数
http://www.lydsy.com/JudgeOnline/problem.php?id=4542 (题目链接)
题意
给出一个素数$P$,一个数串$S$,$m$个询问,每次询问区间$[l,r]$的子串中能被$P$整除的个数。
Solution
如果$[l,n]$的余数与$[r+1,n]$的余数相等,那么子串$[l,r]$就可以被整除,这很显然,然后问题就转化为了莫队板子,转移hash一下维护个数就好。然而为什么转移不能统一啊!强迫症看着有种想死的冲动啊!
UPD:离散化以后用数组就可以实现转移统一了,++,--真尼玛好用。
当$P=2,5$的时候我们需要特判,因为这时$x*10%P==0$,这种情况我们也很好做,直接开个计数器记录一下$0,5$或者$0,2,4,6,8$的个数就可以了。
细节
边界
代码
// bzoj4542
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<vector>
#include<cstdio>
#include<cmath>
#define LL long long
#define inf (1ll<<60)
#define HAS 40007
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std; const int maxn=100010;
int n,m,P,S,pos[maxn];
LL sum,ans[maxn];
char s[maxn];
struct ask {int l,r,id;}q[maxn]; bool cmp(ask a,ask b) {
return pos[a.l]==pos[b.l] ? a.r<b.r : pos[a.l]<pos[b.l];
}
namespace zyt {
struct chain {int w,cnt,next;}c[maxn];
int bin[maxn],f[maxn],head[HAS],cnt;
void push(int x,int val) {
for (int i=head[x%HAS];i;i=c[i].next)
if (c[i].w==x) {c[i].cnt+=val;return;}
c[++cnt]=(chain){x,val,head[x%HAS]},head[x%HAS]=cnt;
}
int query(int x) {
for (int i=head[x%HAS];i;i=c[i].next) if (c[i].w==x) return c[i].cnt;
return 0;
}
void update1(int l,int r) {push(f[r],1);sum+=query(f[r+1]);}
void update3(int l,int r) {sum-=query(f[r+2]);push(f[r+1],-1);}
void update2(int l,int r) {push(f[r+1],1);sum+=query(f[l]);push(f[r+1],-1);push(f[l],1);}
void update4(int l,int r) {push(f[r+1],1);push(f[l-1],-1);sum-=query(f[l-1]);push(f[r+1],-1);}
void main() {
bin[0]=1;
for (int i=1;i<=n;i++) bin[i]=(LL)bin[i-1]*10%P;
for (int i=n;i>=1;i--) f[i]=((LL)(s[i]-'0')*bin[n-i]+f[i+1])%P;
sum=0;
for (int l=1,r=0,i=1;i<=m;i++) {
for (;r<q[i].r;r++) update1(l,r+1);
for (;l>q[i].l;l--) update2(l-1,r);
for (;r>q[i].r;r--) update3(l,r-1);
for (;l<q[i].l;l++) update4(l+1,r);
ans[q[i].id]=sum;
}
for (int i=1;i<=m;i++) printf("%lld\n",ans[i]);
}
}
namespace ZYT {
void main() {
sum=0;int cnts=0;
for (int l=1,r=0,i=1;i<=m;i++) {
for (;r<q[i].r;r++) if ((s[r+1]-'0')%P==0) sum+=r-l+2,cnts++;
for (;r>q[i].r;r--) if ((s[r]-'0')%P==0) sum-=r-l+1,cnts--;
for (;l>q[i].l;l--) {if ((s[l-1]-'0')%P==0) cnts++;sum+=cnts;}
for (;l<q[i].l;l++) {sum-=cnts;if ((s[l]-'0')%P==0) cnts--;}
ans[q[i].id]=sum;
}
for (int i=1;i<=m;i++) printf("%lld\n",ans[i]);
}
}
int main() {
scanf("%d",&P);
scanf("%s",s+1);
n=strlen(s+1);
S=(int)sqrt(n);
scanf("%d",&m);
for (int i=1;i<=m;i++) scanf("%d%d",&q[i].l,&q[i].r),q[i].id=i;
for (int i=1;i<=n;i++) pos[i]=(i-1)/S+1;
sort(q+1,q+1+m,cmp);
if (P!=2 && P!=5) zyt::main();
else ZYT::main();
return 0;
}
【bzoj4542】 Hnoi2016—大数的更多相关文章
- BZOJ4542: [Hnoi2016]大数
Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345.小B还有一个素数P.现在,小 B 提出了 M 个询问,每个 ...
- [BZOJ4542] [Hnoi2016] 大数 (莫队)
Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345.小B还有一个素数P.现在,小 B 提出了 M 个询问,每个 ...
- bzoj4542: [Hnoi2016]大数(莫队)
这题...离散化...$N$和$n$搞错了...查了$2h$...QAQ 考虑$s[l...r]$,可以由两个后缀$suf[l]-suf[r+1]$得到$s[l...r]$代表的数乘$10^k$得到的 ...
- 【莫队】bzoj4542: [Hnoi2016]大数
挺有意思的,可以仔细体味一下的题:看白了就是莫队板子. Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345.小 ...
- bzoj4542 [Hnoi2016]大数 莫队+同余
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4542 题解 我们令 \(f_i\) 表示从 \(i\) 到 \(n\) 位组成的数 \(\bm ...
- 【BZOJ4542】[Hnoi2016]大数 莫队
[BZOJ4542][Hnoi2016]大数 Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345.小B还有一个 ...
- 【LG3245】[HNOI2016]大数
[LG3245][HNOI2016]大数 题面 洛谷 题解 60pts 拿vector记一下对于以每个位置为右端点符合要求子串的左端点, 则每次对于一个询问,扫一遍右端点在vector里面二分即可, ...
- 4542: [Hnoi2016]大数
4542: [Hnoi2016]大数 链接 分析: 如果p等于2或者5,可以根据最后一位直接知道是不是p的倍数,所以直接记录一个前缀和即可. 如果p不是2或者5,那么一个区间是p的倍数,当且仅当$\f ...
- HNOI2016(BZOJ4542) 大数
HNOI2016 Day2 T3 大数 Description 小 B 有一个很大的数 S,长度达到了 N 位:这个数可以看成是一个串,它可能有前导 0,例如00009312345.小B还有一个素数P ...
随机推荐
- springboot 前后端分离开发 从零到整(四、更改密码操作)
前端发送更改密码请求,头部携带token,服务端拦截器拦截头部token并解析,根据token中的信息来查询用户信息.需要登录才能进行的操作是由自己定的,有些操作可以直接放行.具体实现是: 上一章写到 ...
- SICP读书笔记 3.2
SICP CONCLUSION 让我们举起杯,祝福那些将他们的思想镶嵌在重重括号之间的Lisp程序员 ! 祝我能够突破层层代码,找到住在里计算机的神灵! 目录 1. 构造过程抽象 2. 构造数据抽象 ...
- 【Unity】 Cursor学习
CursorLockMode.None 光标行为未修改,第一人称视角下鼠标可以突破窗口. CursorLockMode.Locked 光标锁定到游戏窗口的中心,与全屏与否无关,同时隐藏光标(这一点在3 ...
- 初学node.js-nodejs安装运行(1)
1.Node.js中文官网http://nodejs.cn/download/下载node.js 学习node.js需要有javascript基础,没有基础的可以在http://www.w3schoo ...
- ifconfig命令详情
基础命令学习目录首页 原文链接:https://blog.csdn.net/weixin_37886382/article/details/79716879 许多windows非常熟悉ipconfig ...
- cobbler部署以及使用
常用软件安装及使用目录 资源链接:https://pan.baidu.com/s/1yfVnuSgY5vOTh-B74tpVyw 网盘分享的文件在此 cobbler第一次操作history. ec ...
- 马赛克是否无法逆转?Python简单消除,看片无忧!
图片水印,轻松去除 前段时间玩过了全民K歌,不知道大家是否玩过,还是做得挺好的,就我这嗓子都能唱出张学友的味道,其中更是有消除噪声的功能,就是朋友们都在吃鸡大叫,我在旁边唱歌依然不受影响. 既然声音可 ...
- 团队作业 & alpha最终测试报告
本次ALPHA版本测试是依据Daily Scrum11.16(http://www.cnblogs.com/newbe/p/4101339.html)分配的任务有序进行的,从11.16~11.23.为 ...
- 第二阶段Sprint冲刺会议6
进展:将“录制”及“保存”整合到一起,修复出现的Bug,使之能够正常运行.
- lintcode-517-丑数
517-丑数 写一个程序来检测一个整数是不是丑数. 丑数的定义是,只包含质因子 2, 3, 5 的正整数.比如 6, 8 就是丑数,但是 14 不是丑数以为他包含了质因子 7. 注意事项 可以认为 1 ...