状压DP --- [NOI2015]寿司晚宴

[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\)

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

代码在此

原文地址:https://www.cnblogs.com/reverymoon/p/8921611.html

时间: 2024-10-13 06:03:34

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

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

[BZOJ4197][Noi2015]寿司晚宴 Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴. 在晚宴上,主办方为大家提供了 n−1 种不同的寿司,编号 1,2,3,…,n−1,其中第 i 种寿司的美味度为 i+1 (即寿司的美味度为从 2 到 n). 现在小 G 和小 W 希望每人选一些寿司种类来品尝,他们规定一种品尝方案为不和谐的当且仅当:小 G 品尝的寿司种类中存在一种美味度为 x

BZOJ 4197 NOI 2015 寿司晚宴 状压DP

4197: [Noi2015]寿司晚宴 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 694  Solved: 440[Submit][Status][Discuss] Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴. 在晚宴上,主办方为大家提供了 n?1 种不同的寿司,编号 1,2,3,-,n?1,其中第 i 种寿司的美味度为 i+1 (即

【NOI2015】寿司晚会 题解(状压DP)

[问题描述] 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴. 在晚宴上,主办方为大家提供了 n?1 种不同的寿司,编号 1,2,3,?, n?1, 其中第 i 种寿司的美味度为 i+1  (即寿司的美味度为从 2 到 n ). 现在小 G 和小 W 希望每人选一些寿司种类来品尝,他们规定一种品尝方案 为不和谐的当且仅当:小 G 品尝的寿司种类中存在一种美味度为 x 的寿司,小 W 品尝的寿司中存在一种美味度为 y

N - 寿司晚宴 HYSBZ - 4197 状压dp

N - 寿司晚宴 HYSBZ - 4197 推荐题解 这个题目我觉得还是很难的,借助题解写出来的,题解还看了很久,现在还是不是很理解. 首先这个数比较大有500,如果直接就像这个题目S - Query on a tree 这样写就超时了,而且也存不下这么大的数. 因为这个500以内的质数太多了,然后看了这么多题解你会发现根号500以内的质数只有8个. 而每一个数大于根号500的质数最多一个,所以我们可以先讨论这个小于根号500的质数,然后再判断这个大于根号500的质数. 讨论完之后再判断这个大于

BZOJ 4197: [Noi2015]寿司晚宴( dp )

N^0.5以内的质数只有8个, dp(i, j, k)表示用了前i个大质数(>N^0.5), 2人选的质数(<=N^0.5)集合分别为j, k时的方案数. 转移时考虑当前的大质数p是给哪个人即可. 时间复杂度O(N*2^16) ----------------------------------------------------------------- #include<cstdio> #include<cstring> #include<algorithm&

bzoj4197 [Noi2015]寿司晚宴

Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴. 在晚宴上,主办方为大家提供了 n?1 种不同的寿司,编号 1,2,3,-,n?1,其中第 i 种寿司的美味度为 i+1 (即寿司的美味度为从 2 到 n). 现在小 G 和小 W 希望每人选一些寿司种类来品尝,他们规定一种品尝方案为不和谐的当且仅当:小 G 品尝的寿司种类中存在一种美味度为 x 的寿司,小 W 品尝的寿司中存在一种美味度为 y

[BZOJ]4197: [Noi2015]寿司晚宴

Time Limit: 10 Sec  Memory Limit: 512 MB Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴. 在晚宴上,主办方为大家提供了 n?1 种不同的寿司,编号 1,2,3,-,n?1,其中第 i 种寿司的美味度为 i+1 (即寿司的美味度为从 2 到 n). 现在小 G 和小 W 希望每人选一些寿司种类来品尝,他们规定一种品尝方案为不和谐的当且仅当:小 G 品尝

ZOJ3305Get Sauce 状压DP,

状压DP的题目留个纪念,首先题意一开始读错了,搞了好久,然后弄好了,觉得DFS可以,最后超时,修改了很久还是超时,没办法看了一下n的范围,然后觉得状压可以,但是没有直接推出来,就记忆化搜索了一下,可是一直错,莫名奇妙,然后没办法看了一下题解,发现了下面这个比较好的方法,然后按照这个方程去推,然后敲,也是WA了好多把,写的太搓了,没人家的清楚明了,唉~也算是给自己留个纪念,状压一直做的都不太好~唉~还好理解了, 参考了  http://blog.csdn.net/nash142857/articl

poj 2411 Mondriaan&#39;s Dream(状压DP)

Mondriaan's Dream Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 12232   Accepted: 7142 Description Squares and rectangles fascinated the famous Dutch painter Piet Mondriaan. One night, after producing the drawings in his 'toilet series