SDOI2017遗忘的集合
题面链接
题外话
为了这道题我敲了\(MTT\)、多项式求逆、多项式\(ln\)等模板,搞了将近一天。
sol
最近懒得写题解啊,随便搞搞吧。
看到这个就是生成函数套上去。
\]
\]
\]
常见莫比乌斯套路,令\(T=ij\),交换枚举顺序。
\]
令\(G(x)=lnF(x)\),于是我们得到了一个奇怪的生成函数,\(G(x)\)的每一项就是\(\sum_{i|T}a_i\times\frac iT\)
可以莫比乌斯反演,也可以调和级数暴力减。
感谢Cyhlnj和巨sy
关于$$\ln(1-xi)=-\sum_{j=1}{\infty}\frac{x^{ij}}{j}$$洛谷上有人说是泰勒展开?害我证了好久没证出来。
也许是我太弱了,但我不敢苟同,反正我没看出来泰勒展开怎么搞,如果有人证出来了欢迎留言。
蒯\(zsy\)的博真舒服。
\]
#include<cmath>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define gt getchar()
#define ll long long
#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
inline int in()
{
int k=0;char ch=gt;
while(ch<'-')ch=gt;
while(ch>'-')k=k*10+ch-'0',ch=gt;
return k;
}
const int N=6e5+5;
const double PI=acos(-1);
int a[N],b[N],c[N],YL;
inline int MO(const int &a){return a>=YL?a-YL:a;}
inline int ksm(int a,int k){int r=1;while(k){if(k&1)r=1ll*r*a%YL;a=1ll*a*a%YL,k>>=1;}return r;}
int rev[N],Inv[N];
struct E
{
double x,y;
E(){}
E(double a,double b):x(a),y(b){}
E operator=(const int &a){x=a,y=0;return *this;}
E conj(){return E(x,-y);}
}omg[N];
E operator+(const E &a,const E &b){return E(a.x+b.x,a.y+b.y);}
E operator-(const E &a,const E &b){return E(a.x-b.x,a.y-b.y);}
E operator*(const E &a,const E &b){return E(a.x*b.x-a.y*b.y,a.x*b.y+a.y*b.x);}
inline void fft(E *a,int len)
{
for(int i=0;i<len;++i)if(i<rev[i])std::swap(a[i],a[rev[i]]);
for(int st=2,m=1;st<=len;st<<=1,m<<=1)
for(E *p=a,x,y;p!=a+len;p+=st)
for(int k=0;k<m;++k)
x=p[k],y=omg[len/m*k]*p[k+m],p[k]=x+y,p[k+m]=x-y;
}
inline void mul(int *A,int *B,int *C,int len)
{
int len2=len;len<<=1;int qwq=0;while((1<<qwq)<len)++qwq;--qwq;
for(int i=0;i<len;++i)rev[i]=(rev[i>>1]>>1)|((i&1)<<qwq);
for(int i=0;i<len;++i)omg[i]=E(cos(PI*i/len),sin(PI*i/len));
for(int i=0;i<len;++i)A[i]=MO(A[i]+YL),B[i]=MO(B[i]+YL);
static E mul_a[N],mul_b[N],dfta[N],dftb[N],dftc[N],dftd[N];
for(int i=0;i<len2;++i)mul_a[i]=E(A[i]&32767,A[i]>>15);
for(int i=0;i<len2;++i)mul_b[i]=E(B[i]&32767,B[i]>>15);
for(int i=len2;i<len;++i)mul_a[i]=mul_b[i]=E(0,0);
fft(mul_a,len),fft(mul_b,len);
for(int i=0;i<len;++i)
{
int j=(len-i)&(len-1);E da,db,dc,dd;
da=(mul_a[i]+mul_a[j].conj())*E( 0.5,0);
db=(mul_a[i]-mul_a[j].conj())*E(0,-0.5);
dc=(mul_b[i]+mul_b[j].conj())*E( 0.5,0);
dd=(mul_b[i]-mul_b[j].conj())*E(0,-0.5);
dfta[j]=da*dc,dftb[j]=da*dd,dftc[j]=db*dc,dftd[j]=db*dd;
}
for(int i=0;i<len;++i)mul_a[i]=dfta[i]+dftb[i]*E(0,1);
for(int i=0;i<len;++i)mul_b[i]=dftc[i]+dftd[i]*E(0,1);
fft(mul_a,len),fft(mul_b,len);
for(int i=0;i<len;++i)
{
int da=(ll)(mul_a[i].x/len+0.5)%YL;
int db=(ll)(mul_a[i].y/len+0.5)%YL;
int dc=(ll)(mul_b[i].x/len+0.5)%YL;
int dd=(ll)(mul_b[i].y/len+0.5)%YL;
C[i]=(da+((ll)(db+dc)<<15)+((ll)dd<<30))%YL;
}
}
void get_inv(int *a,int *b,int len)
{
if(len==1){b[0]=ksm(a[0],YL-2);return;}
static int tmp[N];get_inv(a,b,len>>1);mul(a,b,tmp,len);
for(int i=0;i<len;++i)tmp[i]=YL-tmp[i];tmp[0]+=2;mul(tmp,b,b,len);
}
void get_ln(int *a,int *b,int len)
{
static int d[N],inv[N];
for(int i=1;i<len;++i)d[i-1]=1ll*i*a[i]%YL;
get_inv(a,inv,len);mul(d,inv,b,len);
for(int i=len-1;i;--i)b[i]=1ll*b[i-1]*ksm(i,YL-2)%YL;b[0]=0;
}
int main()
{
int n=in();YL=in();int len=1,ans=0;while(len<=n)len<<=1;
for(int i=1;i<=n;++i)a[i]=in();a[0]=1;get_ln(a,a,len);
for(int i=1;i<=n;++i)a[i]=1ll*a[i]*i%YL;
for(int i=1;i<=n;++i)
for(int j=i<<1;j<=n;j+=i)
a[j]=MO(a[j]-a[i]+YL);
for(int i=1;i<=n;++i)if(a[i])++ans;printf("%d\n",ans);
for(int i=1;i<=n;++i)if(a[i])printf("%d ",i);puts("");
return 0;
}
SDOI2017遗忘的集合的更多相关文章
- [SDOI2017]遗忘的集合
[SDOI2017]遗忘的集合 综合了很多套路的题 一看就是完全背包 生成函数! 转化为连乘积形式 Pi....=F 求Ln! 降次才可以解方程 发现方程是: f[i]=∑t|i : bool(t)* ...
- [LOJ2271] [SDOI2017] 遗忘的集合
题目链接 LOJ:https://loj.ac/problem/2271 洛谷:https://www.luogu.org/problemnew/show/P3784 BZOJ太伤身体死活卡不过还是算 ...
- 洛谷P3784 [SDOI2017]遗忘的集合(生成函数)
题面 传送门 题解 生成函数这厮到底还有什么是办不到的-- 首先对于一个数\(i\),如果存在的话可以取无限多次,那么它的生成函数为\[\sum_{j=0}^{\infty}x^{ij}={1\ove ...
- [题解] LuoguP3784 [SDOI2017]遗忘的集合
要mtt的题都是...... 多补了几项就被卡了一整页......果然还是太菜了...... 不说了......来看100分的做法吧...... 如果做过付公主的背包,前面几步应该不难想,所以我们再来 ...
- [BZOJ4913][SDOI2017]遗忘的集合
题解: 首先先弄出$f(x)$的生成函数$$f(x)=\prod_{i=1}^{n} {{(\frac{1}{1-x^i})}}^{a[i]}$$因为$f(x)$已知,我们考虑利用这个式子取推出$a[ ...
- P3784 [SDOI2017]遗忘的集合
非常神仙的一道题! 题意:给出某n个数字跑完全背包m容量的dp数组,求满足要求的字典序最小的n个元素,不知道n是多少. 首先考虑付公主的背包这个题. 对dp数组求一个ln,设它为F. 已知 e^(G1 ...
- 洛谷 3784(bzoj 4913) [SDOI2017]遗忘的集合——多项式求ln+MTT
题目:https://www.luogu.org/problemnew/show/P3784 https://www.lydsy.com/JudgeOnline/problem.php?id=4913 ...
- BZOJ 4913 [Sdoi2017] 遗忘的集合
骂了隔壁的 BZOJ垃圾评测机 我他妈卡了两页的常数了 我们机房的电脑跑的都比BZOJ快
- 【SDOI2017】遗忘的集合
题目描述 好神仙啊,我还真的以为这是个构造题,结果是有唯一解的. 设答案为多项式\(a,a_i\in\{0,1\}\). 则: \[ f(x)=\Pi (\frac{1}{1-x^i})^{a_i} ...
随机推荐
- WebGL——水波纹特效
大家好,今天我ccentry要做一个水波纹特效,我们来看看水波纹特效的做法.首先我们来看一下水波纹特效的效果是怎么样的,请看下图. 我们要做的就是类似这种纹理特效,那么我们来看看是如何制作的吧.首先鲫 ...
- NO--11关于"this"你知道多少
为了更好地理解 this,将 this 使用的场景分成三类: 在函数内部 this 一个额外的,通常是隐含的参数. 在函数外部(顶级作用域中): 这指的是浏览器中的全局对象或者 Node.js 中一个 ...
- mac 下删除行末^M 字符
在vi 打开文件模式下进行字符替换 :%s/^M/\r/g //这里的^M是同时按ctrl+v+m获得的,否则会显示找不到^M
- linux 启动自动运行
开机启动时自动运行程序 Linux 1.加载后, 它将初始化硬件和设备驱动, 然后运行第一个进程init.init根据配置文件继续引导过程,启动其它进程.通常情况下,修改放置在 /etc/rc ...
- linux 下awk后统计某一列数据之和简单的命令
例如有文件test.txt格式如下: aaa:1 bbb:2 cat a|awk -F\: '{print"+"$2}'|xargs echo 0|bc -l
- Netty源码分析第5章(ByteBuf)---->第2节: ByteBuf的分类
Netty源码分析第五章: ByteBuf 第二节: ByteBuf的分类 上一小节简单介绍了AbstractByteBuf这个抽象类, 这一小节对其子类的分类做一个简单的介绍 ByteBuf根据不同 ...
- UVALive 6467 Strahler Order(拓扑序列)
In geology, a river system can be represented as a directed graph. Each river segment is an edge; wi ...
- Notes of Daily Scrum Meeting(11.15)
Notes of Daily Scrum Meeting(11.15) 今天周六我们的主要工作是把这周落下的一些工作补回来,这是写程序的最后阶段,准备进入测试阶段了,所以之前的工作 要补齐,今天大家的 ...
- M1个人贡献分以及转会确定
按照之前的方案,团队成员得分统计表见下: P(Pd*pf) 比重 个人得分 黎柱金 335400 0.1844 63 晏旭瑞 306000 0.1682 59 孙思权 304150 0.1672 ...
- java 实验一
步骤 耗时h 百分比% 需求分析 0.3h 7.5 设计 2.5h 62.5 代码实现 0.5h 12.5 测试 0,2h 5 分析总结 0.5h 12.5 实验一 截图 实验二: 实验三 实现 ...