【WC2014】时空穿梭【组合数】【莫比乌斯反演】【整除分块】【暴力多项式】

题意:TTT 组数据,给一个 nnn 维空间,第 iii 维大小为 [1,mi]∩Z[1,m_i]\cap \Z[1,mi]Z,求大小为 ccc 的严格偏序上升的共线点集个数。答案模 100071000710007

T≤100,n≤11,m≤105,c≤20T\leq 100,n\leq 11,m\leq 10^5,c\leq 20T100,n11,m105,c20

神仙题

设空间大小向量为 mmm,MMM 为坐标最大值。下文中若未特殊说明,对向量无公开定义的运算均定义为其每一维坐标的运算。

考虑第一个点到最后一个点的差向量 xxx,它中间有 gcd⁡(x)−1\gcd(x)-1gcd(x)1 个空隙可以放,gcd⁡\gcdgcd 为所有坐标数值的 gcd⁡\gcdgcd。所以

ans=∑x≤m(gcd⁡(x)−1c−2)∏i=1n(mi−xi)ans=\sum_{x\leq m}\binom{\gcd(x)-1}{c-2}\prod_{i=1}^n(m_i-x_i)ans=xm(c2gcd(x)1)i=1n(mixi)

看到有个 gcd⁡\gcdgcd ,想到反演。

ans=∑d=1M(d−1c−2)∑x≤m[gcd⁡(x)=d]∏i=1n(mi−xi)=∑d=1M(d−1c−2)∑x≤md[gcd⁡(x)=1]∏i=1n(mi−dxi)=∑d=1M(d−1c−2)∑x≤md∑k∣xμ(k)∏i=1n(mi−dxi)=∑d=1M(d−1c−2)∑k∣xμ(k)∑x≤mdk∏i=1n(mi−dkxi)=∑d=1M∑x≤md∏i=1n(mi−dxi)∑k∣d(k−1c−2)μ(dk)ans=\sum_{d=1}^M\binom{d-1}{c-2}\sum_{x\leq m}[\gcd(x)=d]\prod_{i=1}^n(m_i-x_i)\\ =\sum_{d=1}^M\binom{d-1}{c-2}\sum_{x\leq \frac{m}{d}}[\gcd(x)=1]\prod_{i=1}^n(m_i-dx_i)\\ =\sum_{d=1}^M\binom{d-1}{c-2}\sum_{x\leq \frac{m}{d}}\sum_{k\mid x}\mu (k)\prod_{i=1}^n(m_i-dx_i)\\ =\sum_{d=1}^M\binom{d-1}{c-2}\sum_{k\mid x}\mu (k)\sum_{x\leq \frac{m}{dk}}\prod_{i=1}^n(m_i-dkx_i)\\ =\sum_{d=1}^M\sum_{x\leq \frac md}\prod_{i=1}^n(m_i-dx_i)\sum_{k\mid d}\binom{k-1}{c-2}\mu (\frac dk)ans=d=1M(c2d1)xm[gcd(x)=d]i=1n(mixi)=d=1M(c2d1)xdm[gcd(x)=1]i=1n(midxi)=d=1M(c2d1)xdmkxμ(k)i=1n(midxi)=d=1M(c2d1)kxμ(k)xdkmi=1n(midkxi)=d=1Mxdmi=1n(midxi)kd(c2k1)μ(kd)

g(n)=∑d∣n(d−1c−2)μ(nd)g(n)=\sum\limits_{d\mid n}\binom{d-1}{c-2}\mu(\frac nd)g(n)=dn(c2d1)μ(dn),这个随便预处理一下就能算出来。

ans=∑d=1M∑x≤md∏i=1n(mi−dxi)g(d)=∑d=1Mg(d)∏i=1n∑x=1⌊mid⌋(mi−dx)ans=\sum_{d=1}^M\sum_{x\leq \frac md}\prod_{i=1}^n(m_i-dx_i)g(d)\\ =\sum_{d=1}^Mg(d)\prod_{i=1}^n\sum_{x=1}^{\left\lfloor\frac{m_i}{d}\right\rfloor}(m_i-dx)ans=d=1Mxdmi=1n(midxi)g(d)=d=1Mg(d)i=1nx=1dmi(midx)

这样大概是 O(Tmnlog⁡n)\Omicron(Tmn\log n)O(Tmnlogn) 的,有点卡。

看到整除,立刻想到整除分块。

注意到后面是一个关于 dddnnn 次多项式(每个和式次数为 111),如果要整除分块的话只需要求这个多项式的前缀和。

设这个多项式系数为 aia_iai,那么一次区间查询

∑d=lrg(d)f(d)=∑d=lrg(d)∑i=0naidi=∑i=0nai∑d=lrg(d)di\sum_{d=l}^rg(d)f(d)\\ =\sum_{d=l}^rg(d)\sum_{i=0}^na_id^i\\ =\sum_{i=0}^na_i\sum_{d=l}^rg(d)d^id=lrg(d)f(d)=d=lrg(d)i=0naidi=i=0naid=lrg(d)di

后面是和询问无关的,直接预处理就可以 O(n)\Omicron(n)O(n) 回答。

现在的问题是如何维护多项式。 整除分块时一共变化了 O(nm)\Omicron(n\sqrt m)O(nm) 次,每次变化的时候把操作的 111 次多项式做一个多项式乘法或除法就可以了。

然后是喜闻乐见的除 000 问题。记下除了几个 000 多项式即可,但其他人都没提到这个,代码也看不懂,一脸懵逼,可能写法不太一样吧……

复杂度大概是 O(ncm+Tn2m)\Omicron(ncm+Tn^2\sqrt m)O(ncm+Tn2m)

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cctype>
using namespace std;
typedef long long ll;
inline int read()
{int ans=0;char c=getchar();while (!isdigit(c)) c=getchar();while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();return ans;
}
const int MOD=10007;
inline int add(const int& x,const int& y){return x+y>=MOD? x+y-MOD:x+y;}
inline int dec(const int& x,const int& y){return x<y? x-y+MOD:x-y;}
inline int qpow(int a,int p)
{int ans=1;a%=MOD;while (p){if (p&1) ans=ans*a%MOD;a=a*a%MOD,p>>=1;}return ans;
}
const int N=1e5,MAXN=N+5;
int np[MAXN],pl[MAXN],cnt;
inline void init()
{np[1]=1;for (int i=2;i<=N;i++){if (!np[i]) pl[++cnt]=i;for (int j=1,x;(x=i*pl[j])<=N;j++){np[x]=1;if (i%pl[j]==0) break;}}
}
int C[MAXN][20],g[22][MAXN],S[12][22][MAXN];
int a[12],n,c,lim[12],m[12],zero;
inline void mul(int x,int y)
{if (!x&&!y) return (void)(++zero);for (int i=n;i>=1;i--) a[i]=(a[i-1]*x+a[i]*y)%MOD;a[0]=a[0]*y%MOD;
}
inline void div(int x,int y)
{if (!y){if (!x) return (void)(--zero);int ix=qpow(x,MOD-2);for (int i=0;i<n;i++) a[i]=a[i+1]*ix%MOD;a[n]=0; return;}int iy=qpow(y,MOD-2);a[0]=a[0]*iy%MOD;for (int i=1;i<=n;i++) a[i]=dec(a[i],a[i-1]*x%MOD)*iy%MOD;
}
inline int calc(int d,int l,int r)
{for (int i=1;i<=n;i++){int cur=m[i]/d;if (cur<lim[i]){div(dec(0,lim[i]*(lim[i]+1ll)/2%MOD),(ll)lim[i]*m[i]%MOD);lim[i]=cur;mul(dec(0,lim[i]*(lim[i]+1ll)/2%MOD),(ll)lim[i]*m[i]%MOD);}}if (zero) return 0;int ans=0;for (int i=0;i<=n;i++) ans=(ans+a[i]*dec(S[i][c][r],S[i][c][l-1]))%MOD;return ans;
}
int main()
{init();C[0][0]=1;for (int i=1;i<=N;i++){C[i][0]=1;for (int j=1;j<20;j++) C[i][j]=(C[i-1][j]+C[i-1][j-1])%MOD;}for (int t=2;t<22;t++){for (int i=1;i<=N;i++) g[t][i]=C[i-1][t-2];for (int j=1;j<=cnt;j++)for (int i=N/pl[j];i>=1;i--)g[t][i*pl[j]]=dec(g[t][i*pl[j]],g[t][i]);for (int i=0;i<12;i++)for (int d=1;d<=N;d++)S[i][t][d]=add(S[i][t][d-1],qpow(d,i)*g[t][d]%MOD);			}for (int T=read();T;T--){zero=0;n=read(),c=read();int M=N;for (int i=1;i<=n;i++) M=min(M,lim[i]=m[i]=read());memset(a,0,sizeof(a));a[0]=1;for (int i=1;i<=n;i++) mul(dec(0,m[i]*(m[i]+1ll)/2%MOD),(ll)m[i]*m[i]%MOD);int ans=0;for (int l=1,r;l<=M;l=r+1){r=M;for (int i=1;i<=n;i++) r=min(r,m[i]/(m[i]/l));ans=add(ans,calc(l,l,r));}printf("%d\n",ans);}return 0;
}

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

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

相关文章

2021牛客暑期多校训练营1 H Hash Function FFT\NTT

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个数组aaa&#xff0c;你需要找一个最小的模数xxx&#xff0c;使得aaa中每个数都模上xxx之后互不相同。 n≤5e5,ai≤5e5,ai!ajn\le5e5,a_i\le5e5,a_i!a_jn≤5e5,ai​≤5e5,ai​!aj​ 思路&#xff1a…

架构杂谈《六》

超时处理模式在服务化或者微服务架构里&#xff0c;传统的整体应用拆分成多个职责单一的微服务&#xff0c;微服务之间通过某种网络通信协议互相通信和交互&#xff0c;完成特定的功能&#xff0c;然而由于网络通信的不稳定&#xff0c;在设计系统时必须考虑到对网络通信的容错…

【BZOJ4543】Hotel加强版【神仙树形dp】【长链剖分】

题意&#xff1a;给一棵 nnn 个点的树&#xff0c;求两两距离相等的三元组个数。 n≤105n\leq 10^5n≤105 显然相当于是找一个点到这三个点距离相等。子树内和子树外到当前点的距离为某个值的点的个数可以长链剖分快速得到&#xff0c;但统计答案非常棘手。 接下来是个鬼才想…

hdu 6962 I love tree 线段树维护二次函数

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你nnn个点的一颗树&#xff0c;有mmm次询问&#xff0c;每次询问有两个操作&#xff1a; (1)(1)(1)将[a,b][a,b][a,b]路径上的点依次加上12,22,32,...,len2,lenpath(a,b)1^2,2^2,3^2,...,len^2,lenpath(a,…

基于surging 的stage组件设计,谈谈我眼中的微服务

一、前言surging 开源地址&#xff1a;https://github.com/dotnetcore/surging随着业务的发展&#xff0c;并发量的增多&#xff0c;业务的复杂度越来越大&#xff0c;对于系统架构能力要求越来越高&#xff0c;这时候微服务的设计思想应运而生&#xff0c;但是对于微服务需要引…

【PKUSC2018】星际穿越【结论】【倍增dp】

题意&#xff1a;有一张边权为 111 的无向图&#xff0c;对 i∈[2,n]i\in [2,n]i∈[2,n]&#xff0c;iii 与 [li,i−1][l_i,i-1][li​,i−1] 间有边。 qqq 次询问 l,r,xl,r,xl,r,x&#xff0c;表示 xxx 与 [l,r][l,r][l,r] 中的所有点的最短路长度的平均值&#xff0c;其中 l&l…

HDU - 6971 K - I love max and multiply sosdp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 直接求i&j>ki\And j>ki&j>k不是很好求&#xff0c;所以转换成i&jki\And jki&jk的情况。 考虑对a,ba,ba,b求一遍超集&#xff0c;让后从[0,n−1][0,n-1][0,n−1]扫…

推荐10个技术圈优质的公众号大号

公众号有很多但需要什么只有自己知道本次筛选了一批技术圈优质的公众号&#xff0c;主要与python、人工智能、机器学习、技术人生相关希望对你有所帮助!▼★长按二维码&#xff0c;选择“识别二维码”进行关注。▲长按二维码&#xff0c;识别关注简介&#xff1a;Python爱好者社…

【SDOI2013】项链【莫比乌斯反演】【Polya定理】【递推式求通项】【数论】

题意&#xff1a;TTT 组数据&#xff0c;每组给定 n,an,an,a&#xff0c;求满足下列条件的项链数量&#xff1a; 有 nnn 个珠子。每个珠子上有三个 [1,a]∩Z[1,a]\cap \Z[1,a]∩Z 的数&#xff0c;且三个数 gcd⁡\gcdgcd 为 111。相邻两个珠子不同。 珠子旋转、翻转同构&…

HDU - 6955 Xor sum tire树 + 贪心

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个数列aaa&#xff0c;你需要找出来一个长度最小且左端点最靠前的区间&#xff0c;使其异或和≥k\ge k≥k。 n≤1e5,0≤ai,k<230n\le1e5,0\le a_i,k<2^{30}n≤1e5,0≤ai​,k<230 思路&#…

使用Kubeadm创建k8s集群之部署规划(三十一)

前言 上一篇我们讲述了使用Kubectl管理k8s集群&#xff0c;那么接下来&#xff0c;我们将使用kubeadm来启动k8s集群。部署k8s集群存在一定的挑战&#xff0c;尤其是部署高可用的k8s集群更是颇为复杂&#xff08;后续会讲&#xff09;。因此本教程会在部署的过程中穿插讲…

HDU - 6967 G I love data structure 线段树维护矩阵 + 细节

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你两个长度为nnn的数组a,ba,ba,b&#xff0c;你需要完成如下四种操作&#xff1a; 思路&#xff1a; 思路还是比较简单的&#xff0c;首先建一颗线段树&#xff0c;线段树中维护a,b,a2,b2,aba,b,a^2,b^…

【APIO2016】Fireworks【闵可夫斯基和】【凸包向量和】【可并堆】

题意&#xff1a;给一棵带边权的树&#xff0c;可以花费 111 的代价把一条边的边权修改 111&#xff0c;一条边可以修改多次&#xff0c;求使得根到叶子距离相等的最小代价。 n≤3105n\leq 3\times 10^5n≤3105 先暴力 dp 设 f(u,k)f(u,k)f(u,k) 表示 uuu 到子树内所有叶子距…

荐读|属性与可直接访问的数据成员之间应该如何选

写在前面在书写C#代码的时候你是否有过这样的经历&#xff1a;经常混用属性以及公有的数据成员。毕竟他们的用法基本一致&#xff0c;对于使用来说好像没什么区别啊。其实我也经常使用类的公有的数据成员来定义一些常量&#xff0c;为了简单&#xff0c;在一些仅仅需要对外暴露…

【TC10738】TheContest【Hall 定理】【贪心】【二分图匹配】

题意&#xff1a;给 nmn\times mnm 的表格填入 [1,max⁡(n,m)][1,\max(n,m)][1,max(n,m)] 的数&#xff0c;每行每列不能重复&#xff0c;且字典序最小。 n,m≤50n,m\leq 50n,m≤50 数据范围很小&#xff0c;所以是多项式就能过。 考虑每个位置从小到大依次填值&#xff0c;判…

2021牛客暑期多校训练营3 I Kuriyama Mirai and Exclusive Or 差分 + 二进制分治

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个数组aaa&#xff0c;让你实现以下两个操作之后输出数组aaa。 n≤6e5,ai≤230−1n\le6e5,a_i\le2^{30}-1n≤6e5,ai​≤230−1 思路&#xff1a; 下面介绍的思路清奇&#xff0c;反正我想不到。 对…

Lock VS Monitor

介绍介绍对开发人员来说&#xff0c;处理关键代码部分的多线程应用程序是非常重要的。Monitor和lock是c#语言中多线程应用程序中提供线程安全的方法(lock关键字的本质就是对Monitor的封装)。两者都提供了一种机制来确保只有一个线程同时执行代码&#xff0c;以避免代码功能被其…

【UOJ168】元旦老人与丛林【图论证明】【最大权闭合子图】【dinic动态推流】

题意&#xff1a;给一张无向图&#xff0c;判断能否分成两个生成森林。 n≤2103,m≤4103n\leq 2\times 10^3,m\leq 4\times 10^3n≤2103,m≤4103 题目中这样的图称为“丛林”&#xff0c;下面以此来简称。 结论 一张图是丛林的充要条件是它的每一个子图 G(∣V∣,∣E∣)G(|V|,…

2021牛客暑期多校训练营3 C Minimum grid 网络流 + 二分图匹配

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个n∗nn*nn∗n的矩阵&#xff0c;有mmm个点的位置需要填数&#xff0c;填的数范围是0≤k≤1e60\le k\le1e60≤k≤1e6&#xff0c;需要满足第iii行的最大值是bib_ibi​&#xff0c;第iii列的最大值是ci…

【九省联考2018】秘密袭击【树形dp】【生成函数】【线段树合并】【多项式插值】

题意&#xff1a;nnn 个点的带点权的树&#xff0c;点权最大值为 www&#xff0c;求所有连通子图第 kkk 大权值之和模 641236412364123。 n,w≤1666n,w\leq 1666n,w≤1666&#xff0c;时限 5s。 idea 很好的题&#xff0c;可惜被暴力艹过去了。 首先如果点权只有 000 和 111&…