[HNOI2016] 大数(莫队)

problem

luogu-P3245

solution

将这个 nnn 位数从右往左的记录取模 ppp 的结果,即 f(i)=(f(i−1)∗10+si)%pf(i)=(f(i-1)*10+s_i)\% pf(i)=(f(i1)10+si)%p

显然一个子串是 ppp 的倍数必然满足:f(r)−f(l−1)10r−l+1≡0(modp)\frac{f(r)-f(l-1)}{10^{r-l+1}}\equiv 0\pmod p10rl+1f(r)f(l1)0(modp)

但这并不严谨,虽然好像 101010 和质数是互质的,但是当 p=2/5p=2/5p=2/5 的时候上述式子便不成立了。

但是 2,52,52,5 有着非常特殊的性质,即可以通过数的最后一位判断是否该数是否是其倍数。

所以当 p=2,p=5p=2,p=5p=2,p=5 的时候我们可以直接特殊的在线处理。

否则就可以按照上面这样离线下来。因为存在互质,则等价于 f(r)≡f(l−1)(modp)f(r)\equiv f(l-1)\pmod pf(r)f(l1)(modp)

这就相当于是 [l,r][l,r][l,r] 区间内数相同点对的个数,莫队经典题目。

注意 ppp 过大,所以还要再来个离散化。

code

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define maxn 200005
struct node { int l, r, id; }q[maxn];
int n, p, m, B, ans;
char s[maxn];
int f[maxn], g[maxn], h[maxn], block[maxn], a[maxn], b[maxn], cnt[maxn], ret[maxn];void add( int x ) {ans -= cnt[a[x]] * ( cnt[a[x]] - 1 ) / 2;cnt[a[x]] ++;ans += cnt[a[x]] * ( cnt[a[x]] - 1 ) / 2;
}void sub( int x ) {ans -= cnt[a[x]] * ( cnt[a[x]] - 1 ) / 2;cnt[a[x]] --;ans += cnt[a[x]] * ( cnt[a[x]] - 1 ) / 2;
}signed main() {scanf( "%lld %s %lld", &p, s + 1, &m );int n = strlen( s + 1 );if( p == 2 or p == 5 ) {if( p == 2 ) h[0] = h[2] = h[4] = h[6] = h[8] = 1;else h[0] = h[5] = 1;for( int i = 1;i <= n;i ++ ) {f[i] = f[i - 1] + h[s[i] ^ 48];g[i] = g[i - 1] + h[s[i] ^ 48 ] * i;}for( int i = 1, l, r;i <= m;i ++ ) {scanf( "%lld %lld", &l, &r );printf( "%lld\n", g[r] - g[l - 1] - ( f[r] - f[l - 1] ) * ( l - 1 ) );}return 0;}B = sqrt( n );for( int i = 1;i <= n + 1;i ++ ) block[i] = ( i - 1 ) / B + 1;for( int i = 1;i <= m;i ++ ) scanf( "%lld %lld", &q[i].l, &q[i].r ), q[i].r ++, q[i].id = i;sort( q + 1, q + m + 1, []( node x, node y ) { return block[x.l] == block[y.l] ? x.r < y.r : x.l < y.l; } );for( int i = n, x = 1;i;i --, x = x * 10 % p ) {a[i] = ( ( s[i] ^ 48 ) * x + a[i + 1] ) % p;b[i] = a[i];}sort( b + 1, b + n + 2 );int t = unique( b + 1, b + n + 2 ) - b - 1;for( int i = 1;i <= n + 1;i ++ ) a[i] = lower_bound( b + 1, b + t + 1, a[i] ) - b;int curl = 1, curr = 0;for( int i = 1;i <= m;i ++ ) {int l = q[i].l, r = q[i].r;while( curl < l ) sub( curl ++ );while( curl > l ) add( -- curl );while( curr < r ) add( ++ curr );while( curr > r ) sub( curr -- );ret[q[i].id] = ans;}for( int i = 1;i <= m;i ++ ) printf( "%lld\n", ret[i] );return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/316382.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2021牛客暑期多校训练营9

2021牛客暑期多校训练营9 题号题目知识点AA Math ChallengeBBest SubgraphCCellsDDivide-and-conquer on TreeEEyjafjallaFFinancial Order ExecutionGGlass BallsHHappy NumberIIncentive ModelJJam

.NET中的状态机库Stateless

标题&#xff1a;.NET中的状态机库Stateless 作者&#xff1a;Lamond Lu 地址&#xff1a;https://www.cnblogs.com/lwqlun/p/10674018.html[1]介绍什么是状态机和状态模式状态机是一种用来进行对象建模的工具&#xff0c;它是一个有向图形&#xff0c;由一组节点和一组相应的转…

[APIO2016] 划艇(dp + 组合数 + 前缀和优化)

problem luogu-P3643 solution 有个显然的暴力 dpdpdp。设 dp(i,j):dp(i,j):dp(i,j): 到了第 iii 个学校&#xff0c;其参加且派出 jjj 个划艇的方案数。 枚举上一个参加的学校以及派出的划艇&#xff0c;则有转移&#xff1a;dp(i,j)∑k<i,j<jdp(k,j′)dp(i,j)\sum_…

.net core webapi 前后端开发分离后的配置和部署

背景&#xff1a;现在越来越多的企业都采用了在开发上前后端分离&#xff0c;前后端开发上的分离有很多种&#xff0c;那么今天&#xff0c;我来分享一下项目中得的前后端分离。B/S Saas 项目&#xff1a;&#xff08;这个项目可以理解成个人中心&#xff0c;当然不止这么点功…

Happy Number

Happy Number 题意 &#xff1a; 开心数是由仅由2&#xff0c;3&#xff0c;6组成的&#xff0c;问第n个开心数是哪个&#xff1f; 1<n<1e9 题解&#xff1a; 正解应该是&#xff1a; 首先确定k大数有几位&#xff1a; 然后就知道k大数是x位下的第k’大的 把2看成0&a…

[HNOI2015] 接水果(倍增 + 整体二分)

problem luogu-P3242 solution 本题的难点在于如何判定路径之间是否覆盖。 这里我们尝试树常见的 dfs\text{dfs}dfs 序。 考虑 x−yx-yx−y 路径如果要覆盖 u−vu-vu−v 路径需要满足怎样的条件。 以下均假设 dfs(u)<dfs(v),dfs(x)<dfs(y)dfs(u)<dfs(v),dfs(x)&…

ASP.NET Core使用Jaeger实现分布式追踪

前言最近我们公司的部分.NET Core的项目接入了Jaeger&#xff0c;也算是稍微完善了一下.NET团队的技术栈。至于为什么选择Jaeger而不是Skywalking&#xff0c;这个问题我只能回答&#xff0c;大佬们说了算。前段时间也在CSharpCorner写过一篇类似的介绍Exploring Distributed T…

[SCOI2007] 修车(费用流 + 差分时间段建图)

problem luogu-P2053 solution 假设只有一个工作人员。修车顺序为 p1,p2,...,pnp_1,p_2,...,p_np1​,p2​,...,pn​ 是一个 nnn 的排列。 那么对于第 iii 个被修的车的等待时间应为 Tp1...TpiT_{p_1}...T_{p_i}Tp1​​...Tpi​​。 总的等待时间则是 Tp1(Tp1Tp2)...(Tp1..…

长沙开发者技术大会暨.NET技术社区成立大会倒数第13天

待你扬帆起航&#xff0c;一起精彩纷呈&#xff01;长沙开发者技术大会暨.NET技术社区成立大会倒数第13天&#xff01;2019年4月21日期待与你相聚在.NET技术社区&#xff01;我们今天会完成海报制作和报表表单&#xff0c;海报内容初步如下所示&#xff1a;活动信息 长沙开发者…

[TJOI2011] 卡片(网络流 + 质因子优化建图)

problem luogu-P2065 solution 这个拿走一组共两张卡片的操作其实就是一个匹配。 直接两个数的最大公约数大于 111 就建一条边&#xff0c;跑二分图匹配最大流即可。 然而如果直接枚举两个数然后算他们的 gcd\text{gcd}gcd &#xff0c;时间复杂度 O(Tn2log⁡V)O(Tn^2\log…

C#并行编程(1):理解并行

什么是并行并行是指两个或者多个事件在同一时刻发生。在程序运行中&#xff0c;并行指多个CPU核心同时执行不同的任务&#xff1b;对于单核心CPU,严格来说是没有程序并行的。并行是为了提高任务执行效率&#xff0c;更快的获取结果。与并发的区别&#xff1a;并发是指两个或者多…

P2163 [SHOI2007]园丁的烦恼(二维数点模板题)

P2163 [SHOI2007]园丁的烦恼 题意&#xff1a; 在一个二维平面内有一些点&#xff0c;给你一个左上角和右下角的点&#xff0c;问这个范围内有多少点 题解&#xff1a; 二维数点模板题 我们设F(a,b)表示以(0,0)为左下角&#xff0c;(a,b)为右上角的矩阵内有多少点 如图不难…

[CQOI2017] 小Q的表格(分块 + 整除分块 + 数学 + 前缀和)

problem luogu-P3700 solution f(a,b)f(b,a)f(a,b)f(b,a)f(a,b)f(b,a) 意味着我们只用考虑半个棋盘的信息。 b∗f(a,ab)(ab)∗f(a,b)b*f(a,ab)(ab)*f(a,b)b∗f(a,ab)(ab)∗f(a,b) 会发现修改 f(a,b)f(a,b)f(a,b) 就影响 f(a,ab)f(a,ab)f(a,ab) 进而影响 f(a,a2b)…f(a,a2b)\…

Orleans MultiClient 多个Silo复合客户端

介绍Orleans.MultiClient 是一个 Orleans 复合客户端&#xff0c;只需要简单配置就可以简单高效连接和请求 Orleans 服务。Orleans.MultiClient 可以轻松连接多个不同服务的 Orleans 服务,在请求 Orleans 时会根据请求的接口自动寻找 Orleans 客户端&#xff0c;使用者无需关心…

[kuangbin]各种各样的题单

[kuangbin]各种各样的题单 专题1 简单搜索 POJ 1321 POJ 2251 POJ 3278 POJ 3279 POJ 1426 POJ 3126 POJ 3087 POJ 3414 FZU 2150 UVA 11624 POJ 3984 HDU 1241 HDU 1495 HDU 2612 专题2 搜索进阶 HDU 1043 HDU 3567 HDU 2181 HDU 3533 HDU 1560 ZOJ 2477 HDU 3085 HDU 1067 HD…

[CQOI2017] 小Q的棋盘(贪心 / 树形dp)

problem luogu-P3698 solution1-贪心 显然我们想尽可能地少走回头路&#xff0c;即一直往下走。 所以我们可以都会有个初步地猜测是走最长链。 但很快就会想到万一这是一条单链&#xff0c;链中的点都是二度点&#xff0c;走得越深回头浪费的步数也越多。 然后就可能直接…

ASP.NET Core 进程内(InProcess)托管(6)《从零开始学ASP.NET CORE MVC》:

本文出自《从零开始学ASP.NET CORE MVC》推荐文章&#xff1a;ASP.NET Core 中的 Main方法ASP.NET Core 进程内(InProcess)托管在这个视频中我们将讨论在ASP.NET Core中的进程内(InProcess)托管模型什么是Kestrel服务器当一个 ASP.NET Core 应用程序执行的时候&#xff0c;.NET…

约会安排 HDU - 4553

约会安排 HDU - 4553 题意&#xff1a; 题意又丑又长就不叙述了 题解&#xff1a; 这个题一开始理解错了。。。题目相当于是有三种情况占据时间&#xff0c;分别是学习&#xff0c;女神和屌丝&#xff0c;我们用不同的lazy来表示女神和屌丝&#xff0c;根据优先级去更新状态…

ML.NET机器学习、API容器化与Azure DevOps实践(一):简介

打算使用几篇文章介绍一下.NET下的机器学习框架ML.NET的具体应用&#xff0c;包括一些常用的业务场景、算法的选择、模型的训练以及RESTful API的创建、机器学习服务容器化&#xff0c;以及基于Azure DevOps的容器化部署等等相关的内容。如果你从来没有玩过机器学习&#xff0c…

[TJOI2011] 书架(线段数优化dp + 单调栈)

problem luogu-P1295 首先可以列出一个暴力 dpdpdp 转移。 设 f(i):f(i):f(i): 到 iii 为止划分若干组&#xff0c;每组最大值的和 的最小值。 然后枚举最后一组&#xff0c;即 iii 所在组的开头 jjj&#xff0c;则 f(i)min⁡{f(j−1)max⁡j≤k≤i{ak}}f(i)\min\Big\{f(j-1…