[NOI2015]寿司晚宴

题目描述

为了庆祝NOI的成功开幕,主办方为大家准备了一场寿司晚宴。

小G和小W作为参加NOI的选手,也被邀请参加了寿司晚宴。

在晚宴上,主办方为大家提供了n−1种不同的寿司,编号1,2,3,⋯,n-1,其中第种寿司的美味度为i+1(即寿司的美味度为从2到n)。

现在小G和小W希望每人选一些寿司种类来品尝,他们规定一种品尝方案为不和谐的当且仅当:

小G品尝的寿司种类中存在一种美味度为x的寿司,小W品尝的寿司中存在一种美味度为y的寿司,而x与y不互质。

现在小G和小W希望统计一共有多少种和谐的品尝寿司的方案(对给定的正整数p取模)。

注意一个人可以不吃任何寿司

输入格式:

从文件dinner.in中读入数据。

输入文件的第1行包含2个正整数n,p中间用单个空格隔开,表示共有n种寿司,最终和谐的方案数要对p取模。

输出格式:

输出到文件dinner.out中。

输出一行包含1个整数,表示所求的方案模p的结果。

数据范围:

\(30pt : 2 <= n <= 30\)

\(50pt : 2 <= n <= 100\)

\(70pt : 2 <= n <= 200\)

\(100pt : 2 <= n <= 500\)

\(p <= 1000000000\)

嗯。。。。。。。。。怎么讲呢?虽然自己很快就想出来了,但是感觉自己还是很弱。

周六下午,一看这数据范围,\(O(n^{3})\)的\(DP\)

\(dp(i,j,k)\)表示枚举到第\(i\)个数字,第\(j\)个质数,第\(k\)个。。。。。哪来的三个维???

突然想到大佬提起过状压。

还能压什么?压因子啊。

看了下500以内的素数个数:94个。。。。。。不现实啊

突然想到\(\sqrt{500}=22\)内只有\(2,3,5,7,11,13,17,19\)这\(8\)个质数

\(dp(i,S)\)表示枚举到数字\(i\),因子状态为\(S\)

复杂度\(O(2^8*n)\)。。。。太小了吧。。。。。

不是两个集合吗?加一维:\(dp(i,S1,S2)\)表示枚举到数字\(i\),第一个集合的因子状态\(S1\),第二个\(S2\)

嗯。。。。。。大于\(\sqrt{n}\)的怎么办???

放置了一会去想其他题目,突然懂了大于\(\sqrt{n}\)的因子不会在一个一个数中出现两次,因此可以把每个大因子集合单独拿出来\(DP\)

???做完了???其实思路是差不多完了。

进入正题:

对于第一维根本没有必要保持,可以去掉。

设\(sta[i]\)表示\(i\)的因子状压出来的数字。

小因子转移方程:

\(dp(S1|sta[i],S2)=dp(S1|sta[i],S2)+dp(S1,S2)(sta[i]\;and\;S2==0)\)

\(dp(S1,S2|sta[i])=dp(S1,S2|sta[i])+dp(S1,S2)(sta[i]\;and\;S1==0)\)

而对于大因子,我们需要多开一维来记录大因子允许存在于第几个集合中

即\(f(0/1,S1,S2)\)

转移方程:(以下转移条件同上,略去)

\(f(0,S1|sta[i],S2)=f(0,S1|sta[i],S2)+f(0,S1,S2)\)

\(f(1,S1|sta[i],S2)=f(1,S1|sta[i],S2)+f(1,S1,S2)\)

而最后合并的时候,因为两个\(f\)数组中都考虑了大因子不存在的情况,因此要减去一个,减什么?

还有什么没有考虑大因子呢?

自然是\(dp(S1,S2)\)

大因子DP合并到小因子DP转移方程:

\(dp(S1,S2)=f(0,S1,S2)+f(1,S1,S2)-dp(S1,S2)\)

最后答案即为:

\(\sum_{i=0}^{2^{8}-1} \sum_{j=0}^{2^{8}-1} dp(i,j)\)

时间复杂度:\(O(n*2^{16})\)

补充:

模的是\(10^{10}\)是\(long\;\;long\)范围的,不能开\(int\)

卡常代码,不建议仿生,可以选择参考其他人的

代码在此

[NOI2015]寿司晚宴 --- 状压DP的更多相关文章

  1. 【BZOJ4197】[Noi2015]寿司晚宴 状压DP+分解质因数

    [BZOJ4197][Noi2015]寿司晚宴 Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴 ...

  2. B4197 [Noi2015]寿司晚宴 状压dp

    这个题一开始想到了唯一分解定理,然后状压.但是显然数组开不下,后来想到每个数(n<500)大于19的素因子只可能有一个,所以直接单独存就行了. 然后正常状压dp就很好搞了. 题干: Descri ...

  3. bzoj4197 [Noi2015]寿司晚宴——状压DP

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4197 首先,两个人选的数都互质可以看作是一个人选了一个数,就相当于选了一个质因数集合,另一个 ...

  4. BZOJ 4197: [Noi2015]寿司晚宴 状压dp+质因数分解

    挺神的一道题 ~ 由于两个人选的数字不能有互质的情况,所以说对于一个质因子来说,如果 1 选了,则 2 不能选任何整除该质因子的数. 然后,我们发现对于 1 ~ 500 的数字来说,只可能有一个大于 ...

  5. [NOI2015]寿司晚宴——状压dp

    题目转化:将2~n的数分成两组,可以不选,使得这两组没有公共的质因子.求方案数. 选择了一个数,相当于选择了它的所有质因子. 30分: 发现,n<=30的时候,涉及到的质因子也就10个.2,3, ...

  6. 【BZOJ-4197】寿司晚宴 状压DP

    4197: [Noi2015]寿司晚宴 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 694  Solved: 440[Submit][Status] ...

  7. BZOJ 4197 NOI 2015 寿司晚宴 状压DP

    4197: [Noi2015]寿司晚宴 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 694  Solved: 440[Submit][Status] ...

  8. NOI 2015 寿司晚宴 (状压DP+分组背包)

    题目大意:两个人从2~n中随意取几个数(不取也算作一种方案),被一个人取过的数不能被另一个人再取.两个人合法的取法是,其中一个人取的任何数必须与另一个人取的每一个数都互质,求所有合法的方案数 (数据范 ...

  9. [NOI2015][bzoj4197] 寿司晚宴 [状压dp+质因数]

    题面 传送门 思路 首先,要让两个人选的数字全部互质,那么有一个显然的充要条件:甲选的数字的质因数集合和乙选的数字的质因数集合没有交集 30pt 这种情况下n<=30,也就是说可用的质数只有10 ...

随机推荐

  1. Angular测试遇到的小坑

    Angular测试遇到的小坑 Error: Expected to be running in 'ProxyZone', but it was not found 检查doneFn的写法是否正确,位置 ...

  2. JSP和Servlet面试题

    1.讲下servlet的执行流程. Servlet的执行流程也就是servlet的生命周期,当服务器启动的时候生命周期开始,然后通过init()<启动顺序根据web.xml里的startup-o ...

  3. win8扁平风格的物流公司网站后台管理模板——后台

    链接:http://pan.baidu.com/s/1o79Zp2M 密码:tqrz

  4. 利用PCA可视化异常点

    异常点往往是由于某一个特征或者多个特征数值异常.但是对于多维度特征无法直接进行可视化观测异常点,利用PCA技术进行维度缩减,可以在二维或者三维空间上进行可视化展示. 原数据如下: from sklea ...

  5. 4-Python数据类型之元组-字符串

    目录 1 元组概念 1.1 元祖的特点 1.2 元组的定义 1.3 元组的访问 1.4 元组的查询 2 命名元组 3 字符串 3.1 字符串的基本操作 3.1.1 字符串的访问 3.1.2 字符串的拼 ...

  6. Ubuntu之设置应用开机自启动

    前言 前面使用oricle-Linux的时候,设置开机自启动使用的是chkconfig,现在使用ubuntu的时候发现Ubuntu系统没有了RH系统中的 chkconfig命令,因此研究了一下ubun ...

  7. python近期遇到的一些面试问题(三)

    python近期遇到的一些面试问题(三) 整理一下最近被问到的一些高频率的面试问题.总结一下方便日后复习巩固用,同时希望可以帮助一些朋友们. 前两期点这↓ python近期遇到的一些面试问题(一) p ...

  8. nfs服务器配置

    安装 nfs-utils,该软件包提供了 NFS 工具: # yum install nfs-utils 配置启动脚本,使得共享在系统每次启动时都有效: # chkconfig --add rpcbi ...

  9. 微信access_token和refresh_token保存于redis

    简介 通常理解的access_token和refresh_token access_token是用来对客户端进行认证的,类似与密码,有一定的有效期.当过期后可使用refresh_token重新获取一个 ...

  10. ssh使两台机器建立连接

    ssh利用口令建立连接过程: 客户端--> 发送连接请求 --> 远程主机 --> 返回远程主机的公钥 --> 公钥加密客户端私钥+客户端公钥返回远程主机 --> 远程主 ...