$n \leq 500$,$2-n$这些数字,两个人挑,可以重复挑,问有几种方案中,一个人选的所有数字与另一个人选的所有数字都互质。

不像前两题那么抠脚。。

如果$n$比较小的话,可以把两个人选的数字对应的质因子状压一下,$f(i,j,k)$--前$i$个数,第一个人选状态$j$,第二个人选状态$k$,状态表示质因子。

质因子的根号相关性质:根号n之后的每个质因子最多只会在一个数里出现一次。也就是说,对根号n前面的质因子我们是可能一次选若干种的,但根号n后面的每个质因子每次只能选一种,所以可以单独枚举,再用根号n以前的状态表示。$g(i,j,k)$--前$i$个含质数$p$的数,只让第一个人选,第二个人保持状态$k$的方案数;$h(i,j,k)$--前$i$个含质数$p$的数,只让第二个人选,第一个人保持状态$j$的方案数。如此dp完,$ans(j,k)$表示最后的$f(i,j,k)$,那么$ans(j,k)=g(t,j,k)+h(t,j,k)-ans(j,k)$,其中$t$表示含质因数$p$的数的个数,因为两个人都不选的方案算了两次。

 //#include<iostream>
#include<cstring>
#include<cstdio>
//#include<math.h>
//#include<set>
//#include<queue>
//#include<bitset>
//#include<vector>
#include<algorithm>
#include<stdlib.h>
using namespace std; #define LL long long
int qread()
{
char c; int s=,f=; while ((c=getchar())<'' || c>'') (c=='-') && (f=-);
do s=s*+c-''; while ((c=getchar())>='' && c<=''); return s*f;
} //Pay attention to '-' , LL and double of qread!!!! int n,mod;
#define maxn 555
int f[][maxn][maxn],g[][maxn][maxn],h[][maxn][maxn],cur=; int prime[maxn],lp,xx[maxn],ss[maxn]; bool notprime[maxn];
void makeprime()
{
ss[]=; ss[]=; ss[]=; ss[]=;
ss[]=; ss[]=; ss[]=; ss[]=;
for (int i=;i<=n;i++)
{
if (!notprime[i]) {prime[++lp]=i; xx[i]=i;}
for (int j=,tmp;j<=lp && 1ll*i*prime[j]<=n;j++)
{
notprime[tmp=i*prime[j]]=;
xx[tmp]=prime[j];
if (!(i%prime[j])) break;
}
}
} int num[maxn],len; int S,P;
void mm(int x)
{
len=;
while (x>) {num[++len]=xx[x]; x/=xx[x];}
sort(num+,num++len); len=unique(num+,num++len)-num-;
S=; for (int i=;i<=len;i++) if (num[i]<=) S|=<<ss[num[i]];
if (num[len]>) P=num[len]; else P=;
} int list[maxn][maxn];
void play(int &x,int v) {x+=v; x-=x>=mod?mod:;}
int main()
{
n=qread(); mod=qread();
makeprime();
for (int i=;i<=n;i++) {mm(i); list[P][++list[P][]]=S;} int ts=<<; f[][][]=; cur=;
for (int i=;i<=list[][];i++)
{
int u=list[][i];
memset(f[cur^],,sizeof(f[cur^]));
for (int j=;j<ts;j++)
for (int k=;k<ts;k++) if (f[cur][j][k])
{
play(f[cur^][j][k],f[cur][j][k]);
int nj=j|u; if ((nj&k)==) play(f[cur^][nj][k],f[cur][j][k]);
int nk=k|u; if ((j&nk)==) play(f[cur^][j][nk],f[cur][j][k]);
}
cur^=;
} for (int j=;j<ts;j++)
for (int k=;k<ts;k++)
f[][j][k]=f[cur][j][k];
for (int i=;i<=n;i++) if (!notprime[i])
{
cur=;
for (int j=;j<ts;j++)
for (int k=;k<ts;k++)
g[][j][k]=f[][j][k],h[][j][k]=f[][j][k];
for (int t=;t<=list[i][];t++)
{
int u=list[i][t];
memset(g[cur^],,sizeof(g[cur^]));
memset(h[cur^],,sizeof(h[cur^]));
for (int j=;j<ts;j++)
for (int k=;k<ts;k++) if (g[cur][j][k])
{
play(g[cur^][j][k],g[cur][j][k]);
int nj=j|u; if ((nj&k)==) play(g[cur^][nj][k],g[cur][j][k]);
}
for (int j=;j<ts;j++)
for (int k=;k<ts;k++) if (h[cur][j][k])
{
play(h[cur^][j][k],h[cur][j][k]);
int nk=k|u; if ((j&nk)==) play(h[cur^][j][nk],h[cur][j][k]);
}
cur^=;
}
for (int j=;j<ts;j++)
for (int k=;k<ts;k++)
f[][j][k]=((g[cur][j][k]+h[cur][j][k]-f[][j][k])%mod+mod)%mod;
} int ans=;
for (int j=;j<ts;j++)
for (int k=;k<ts;k++)
play(ans,f[][j][k]);
printf("%d\n",ans);
return ;
}

LOJ#2131. 「NOI2015」寿司晚宴的更多相关文章

  1. 【LOJ】#2131. 「NOI2015」寿司晚宴

    题解 怎么NOI2015D1--全是一眼秒的sb题--然后我代码全都写跪一遍= = 要是NOI2015是IOI赛制我就可以AK啦(大雾) 代码能力直线下降,NOI2018滚粗预定了啊TAT 我是不是要 ...

  2. 「NOI2015」寿司晚宴 解题报告

    「NOI2015」寿司晚宴 这个题思路其实挺自然的,但是我太傻了...最开始想着钦定一些,结果发现假了.. 首先一个比较套路的事情是状压前8个质数,后面的只会在一个数出现一次的再想办法就好. 然后发现 ...

  3. loj#2129. 「NOI2015」程序自动分析

    题目链接 loj#2129. 「NOI2015」程序自动分析 题解 额... 考你会不会离散化优化常数 代码 #include<queue> #include<cstdio> ...

  4. *LOJ#2134. 「NOI2015」小园丁与老司机

    $n \leq 5e4$个平面上的点,从原点出发,能从当前点向左.右.上.左上或右上到达该方向最近的给定点.问三个问:一.最多经过多少点:二.前一问的方案:三.其所有方案种非左右走的边至少要开几辆挖掘 ...

  5. LOJ#2132. 「NOI2015」荷马史诗

    $n \leq 100000$个数字,放进$k$叉树里,一个点只能放一个数,使所有数字乘以各自深度这个值之和最小的同时,最大深度的数字最小. 哈夫曼.这是我刚学OI那段时间看到的,感觉就是个很无聊的贪 ...

  6. Loj #2192. 「SHOI2014」概率充电器

    Loj #2192. 「SHOI2014」概率充电器 题目描述 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品--概率充电器: 「采用全新纳米级加工技术,实现元件与导线能否通电完 ...

  7. Loj #3096. 「SNOI2019」数论

    Loj #3096. 「SNOI2019」数论 题目描述 给出正整数 \(P, Q, T\),大小为 \(n\) 的整数集 \(A\) 和大小为 \(m\) 的整数集 \(B\),请你求出: \[ \ ...

  8. Loj #3093. 「BJOI2019」光线

    Loj #3093. 「BJOI2019」光线 题目描述 当一束光打到一层玻璃上时,有一定比例的光会穿过这层玻璃,一定比例的光会被反射回去,剩下的光被玻璃吸收. 设对于任意 \(x\),有 \(x\t ...

  9. Loj #3089. 「BJOI2019」奥术神杖

    Loj #3089. 「BJOI2019」奥术神杖 题目描述 Bezorath 大陆抵抗地灾军团入侵的战争进入了僵持的阶段,世世代代生活在 Bezorath 这片大陆的精灵们开始寻找远古时代诸神遗留的 ...

随机推荐

  1. >详解<栈

  2. 十二、MySQL 查询数据

    MySQL 查询数据 MySQL 数据库使用SQL SELECT语句来查询数据. 你可以通过 mysql> 命令提示窗口中在数据库中查询数据,或者通过PHP脚本来查询数据. 语法 以下为在MyS ...

  3. matplotlib(一)——matplotlib横轴坐标密集字符覆盖

    一.问题描述 具体问题是: 用python库matplotlib进行数据的图表展示: 图表展示图形横坐标有将近100个自定义值需要显示: 保存矢量图(svg),保存后发现横坐标过于密集,坐标值之间有覆 ...

  4. js 发送验证码倒计时

    首先写一个按钮: <input type="button" id="btn" value="免费获取验证码" onclick=&quo ...

  5. 单片机入门学习笔记6:新唐单片机N76E003

    学习新唐单片机是从2018年3月开始的,之前一点也不懂这一块单片机,之后脉络变的越来越清晰. 由于N76E003档次太低,新塘科技官方的管脚配置,芯片选型……都没有这一块芯片,资料唯独只有:芯片的数据 ...

  6. Uva:11401-Triangle Counting

    Triangle Counting Time limit1000 ms Description You are given n rods of length 1, 2-, n. You have to ...

  7. [USACO]奶牛博览会(DP)

    Description 奶牛想证明他们是聪明而风趣的.为此,贝西筹备了一个奶牛博览会,她已经对N头奶牛进行了面试,确定了每头奶牛的智商和情商. 贝西有权选择让哪些奶牛参加展览.由于负的智商或情商会造成 ...

  8. 刷表法动态规划:HOJ11391_Word Clouds Revisited

    题目大意,给若干方块,让把方块拍成若干行,使得最终高度最小.其中,每行有宽度限制,高度为每行中最高的箱子的高度. 于是,很直观的认为,这个题可能也许大概应该是个动态规划的题. 于是,设DP[K]为K及 ...

  9. xcode6没有prefix.pch预编译文件解决办法

    注意到Xcode6创建的工程没有prefix.pch. 于是手动创建. 在other下选择pch文件 接着到工程的build setting下设置开启预编译并配置路径(文件的路径.因为我新建在cofi ...

  10. adb命令模拟按键事件

    //这条命令相当于按了设备的Backkey键 adb shell input keyevent 4 //可以解锁屏幕 adb shell input keyevent  82 //在屏幕上做划屏操作, ...