bzoj3992
题解:
求模素数 p 原根的方法:对 p-1 进行素因子分解,记pi为p-1的第i个因子,若恒有a^((p-1)/pi) mod p ≠ 1 成立,则 a 就是 p 的原根。(对于合数求原根,只需把 p-1 换成 phi(p) 即可)
首先比较暴力是f[i][j]表示前i个,乘积为j
然后是n*m^2的
我们可以利用原根将每个数变成g^x
这样就变成了加和
可以利用生成函数的思想
然后分治+fft就可以了
代码:
#include <bits/stdc++.h>
using namespace std;
#define rint register int
#define rep(i,h,t) for(rint i=h;i<=t;i++)
#define dep(i,t,h) for(rint i=t;i>=h;i--)
#define IL inline
const double pi=acos(-1.0);
const int N=3e4;
int n,m,l,r[N],a[N],b[N],w[N],c[N],g,kk,G=;
int p=;
IL int fsp(int x,int y,int p)
{
int ans=;
while (y)
{
if(y&) ans=1ll*ans*x%p;
x=1ll*x*x%p;
y>>=;
}
return ans;
}
IL void jf(int &x,int y)
{
x+=y;
if (x>p) x-=p;
}
IL void fft(int *a,int o)
{
rep(i,,n-) if (i>r[i]) swap(a[i],a[r[i]]);
for (int i=;i<n;i*=)
{
int wn=fsp(G,(p-)/(i*),p); w[]=;
rep(j,,i-) w[j]=(1ll*w[j-]*wn)%p;
for (int j=;j<n;j+=(i*))
{
int *x=a+j,*y=a+i+j;
for (rint k=;k<i;k++)
{
const int t=(1ll*w[k]*y[k])%p;
y[k]=x[k]-t; if (y[k]<) y[k]+=p;
x[k]+=t; if (x[k]>p) x[k]-=p;
}
}
}
if (o==-)
{
reverse(&a[],&a[n]);
for (int i=,inv=fsp(n,p-,p);i<n;i++)
a[i]=1ll*a[i]*inv%p;
rep(i,kk,m)
jf(a[i%kk],a[i]),a[i]=;
}
}
IL void query()
{
l=;
for (n=;n<=m;n<<=) l++;
rep(i,,n-) r[i]=(r[i/]/)|((i&)<<(l-));
fft(a,); fft(b,);
rep(i,,n-) a[i]=1ll*a[i]*b[i]%p;
fft(a,-);
}
IL void get_g(int x)
{
rep(i,,x-)
{
int j;
for (j=;j<m;j++)
if (fsp(i,j,m)==) break;
if (j==m-)
{
g=i; break;
}
}
}
struct re{
int a[N];
}now;
re fsp2(int x)
{
if (x==) return(now);
re tmp=fsp2(x/);
memcpy(b,tmp.a,sizeof(tmp.a));
memcpy(a,tmp.a,sizeof(tmp.a));
query();
if (x%)
{
memcpy(b,c,sizeof(c));
query();
}
memcpy(tmp.a,a,sizeof(a));
return(tmp);
}
int f[N];
int main()
{
freopen("1.in","r",stdin);
freopen("1.out","w",stdout);
ios::sync_with_stdio(false);
int x,s;
cin>>n>>m>>x>>s; kk=m-;
rep(i,,s) cin>>a[i];
get_g(m);
rep(i,,m-) f[fsp(g,i,m)]=i;
m*=;
rep(i,,s) if (a[i]) now.a[f[a[i]]]++,c[f[a[i]]]++;
fsp2(n);
cout<<(a[f[x]]+p)%p;
return ;
}
bzoj3992的更多相关文章
- 【BZOJ3992】序列统计(动态规划,NTT)
[BZOJ3992]序列统计(动态规划,NTT) 题面 BZOJ 题解 最裸的暴力 设\(f[i][j]\)表示前\(i\)个数,积在膜意义下是\(j\)的方案数 转移的话,每次枚举一个数,直接丢进去 ...
- 【bzoj3992】 SDOI2015—序列统计
http://www.lydsy.com/JudgeOnline/problem.php?id=3992 (题目链接) 题意 集合${S}$中有若干个不超过${m}$的非负整数,问由这些数组成一个长度 ...
- [BZOJ3992][SDOI2015]序列统计(DP+原根+NTT)
3992: [SDOI2015]序列统计 Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 1888 Solved: 898[Submit][Statu ...
- 【BZOJ3992】[SDOI2015]序列统计 NTT+多项式快速幂
[BZOJ3992][SDOI2015]序列统计 Description 小C有一个集合S,里面的元素都是小于M的非负整数.他用程序编写了一个数列生成器,可以生成一个长度为N的数列,数列中的每个数都属 ...
- BZOJ3992: [SDOI2015]序列统计
Description 小C有一个集合S,里面的元素都是小于M的非负整数.他用程序编写了一个数列生成器,可以生成一个长度为N的数列,数列中的每个数都属于集合S. 小C用这个生成器生成了许多这样的数列. ...
- Bzoj3992:[SDOI2015]序列统计
题面 Bzoj Sol pts 1 大暴力很简单,\(f[i][j]\)表示到第\(i\)个位置,前面积的模为\(j\)的方案 然后可以获得\(10\)分的好成绩 # include <bits ...
- 【BZOJ3992】【SDOI2015】序列统计 原根 NTT
题目大意 有一个集合\(s\),里面的每个数都\(\geq0\)且\(<m\). 问有多少个长度为\(n\)的数列满足这个数列所有数的乘积模\(m\)为\(x\).答案模\(1004535809 ...
- 【BZOJ3992】【SDOI2015】序列统计
数论劲啊 原题: 小C有一个集合S,里面的元素都是小于M的非负整数.他用程序编写了一个数列生成器,可以生成一个长度为N的数列,数列中的每个数都属于集合S. 小C用这个生成器生成了许多这样的数列.但是小 ...
- 2018.12.31 bzoj3992: [SDOI2015]序列统计(生成函数+ntt+快速幂)
传送门 生成函数简单题. 题意:给出一个集合A={a1,a2,...as}A=\{a_1,a_2,...a_s\}A={a1,a2,...as},所有数都在[0,m−1][0,m-1][0,m− ...
随机推荐
- linux系统设置静态IP,DHCP网络服务,DNS
一.设置静态IP及DHCP网络服务 kk@yuanqiangfei:~$ cat /etc/network/interfaces # This file describes the network i ...
- 2017.12.10《“剑锋OI”普及组多校联盟系列赛(14)#Sooke#Kornal 的课余时间 》分析报告
报告内容如下 - - [导语] ------ 太晚了,时间也紧,一切尽量从简吧 PS:本文题目来自剑锋OI 所以废话也不多说,进入正题吧,代码直接跟在题目后边儿,主要分析在代码前,次要的就写在代码后面 ...
- 专题:DP杂题1
A POJ 1018 Communication System B POJ 1050 To the Max C POJ 1083 Moving Tables D POJ 1125 Stockbroke ...
- bigfile tablespace
背景 这次终于有个linux实际迁移oracle的机会了,之前都是学习实验.想起最早时,都是windows搞oracle,又让我想起多年期一个项目,数据量太大及计算逻辑太复杂,我用存储过程 ...
- canvas - 钟表
Demo : Demo Demo截图: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta ...
- DALSA相机开发--修改参数
DALSA gige相机有两种方式可以获取到相机相关参数,一个是读取相机里面的xml文件:另外一个是读取相对应的寄存器的值. 对于修改寄存器的值,有两个相应的函数: 1)GevSetFeatureVa ...
- SSL For Free 申请免费https SSL 凭证
打开 SSL For Free网站(https://www.sslforfree.com) ,在输入框中填入你要申请 Let’s Encrypt 凭证的网域名称,可以用空白来分隔不同的网址,例如[su ...
- const成员函数和mutable关键字
一.const成员函数 class MyClass { public: void fun() const { } private: int m_nValue; } const成员函数内不能修改成员变量 ...
- spring-data-redis和jedis版本对应问题
项目中使用spring-data-redis总是出现跟jedis版本不一致的问题而导致异常. java.lang.ClassNotFoundException 下面就记录两者版本对应关系: sprin ...
- hdu2602 Bone Collector 01背包
Many years ago , in Teddy’s hometown there was a man who was called “Bone Collector”. This man like ...