[UOJ#129][BZOJ4197][Noi2015]寿司晚宴
[UOJ#129][BZOJ4197][Noi2015]寿司晚宴
试题描述
为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴。小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴。
输入
输入文件的第 1 行包含 2 个正整数 n,p,中间用单个空格隔开,表示共有 n 种寿司,最终和谐的方案数要对 p 取模。
输出
输出一行包含 1 个整数,表示所求的方案模 p 的结果。
输入示例
输出示例
数据规模及约定
2≤n≤500
0<p≤1000000000
题解
果然还是第三题最厉害。
根据“互质”这个条件,我们发现每个数可以用它的质因数表示即可。然后发现一个性质:每个数最多有一个质因数大于 sqrt(500);而小于 sqrt(500) 的质数又只有 8 个。
根据以上性质,我们就可以进行状压 dp 了。
首先对 2 到 n 的每个数处理出两个值:big 最大质因数(若这个质因数小于 sqrt(500) 则 big = 1),s 这个数包含较小质因数的集合(易知 s 是一个 8 位的二进制);
现在我们再读一遍题,问题就转化成了给每个数进行三种决定(把它给小 G,给小 W,或都不给),满足小 G、小 W 拿到的数的质因子没有交集;
对于小于 sqrt(500) 部分的质因子显然可以状压解决,对于那些含有大于 sqrt(500) 的质因子的数我们把它们按 big 值分类,那么每一类中的数的主人必须是同一个,或者没有主人。
分析到这里,怎样 dp 应该很明了了吧。
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cctype>
#include <algorithm>
using namespace std; const int BufferSize = 1 << 16;
char buffer[BufferSize], *Head, *Tail;
inline char Getchar() {
if(Head == Tail) {
int l = fread(buffer, 1, BufferSize, stdin);
Tail = (Head = buffer) + l;
}
return *Head++;
}
int read() {
int x = 0, f = 1; char c = Getchar();
while(!isdigit(c)){ if(c == '-') f = -1; c = Getchar(); }
while(isdigit(c)){ x = x * 10 + c - '0'; c = Getchar(); }
return x * f;
} #define maxn 510
#define maxs 256 int n, MOD, f[maxn][3][maxs][maxs], prime[] = {2, 3, 5, 7, 11, 13, 17, 19}; struct Num {
int big, s; bool operator < (const Num& t) const { return big < t.big; } void getNum(int x) {
s = 0;
for(int i = 0; i < 8; i++) if(x % prime[i] == 0) {
s |= (1 << i);
while(x % prime[i] == 0) x /= prime[i];
}
big = x;
return ;
}
} ns[maxn]; int main() {
n = read(); MOD = read(); for(int i = 2; i <= n; i++) ns[i].getNum(i);
sort(ns + 2, ns + n + 1);
int all = (1 << 8) - 1;
f[1][0][0][0] = 1;
ns[1].big = 1;
for(int i = 1; i < n; i++)
for(int cho = 0; cho < 3; cho++)
for(int s1 = 0; s1 <= all; s1++)
for(int s2 = 0; s2 <= all; s2++) if(!(s1 & s2) && f[i][cho][s1][s2]) {
int tmp = f[i][cho][s1][s2];
if(ns[i+1].big == 1) {
(f[i+1][0][s1|ns[i+1].s][s2] += tmp) %= MOD;
(f[i+1][0][s1][s2|ns[i+1].s] += tmp) %= MOD;
(f[i+1][0][s1][s2] += tmp) %= MOD;
}
else if(ns[i+1].big == ns[i].big) {
if(cho == 0) {
(f[i+1][0][s1][s2] += tmp) %= MOD;
(f[i+1][1][s1|ns[i+1].s][s2] += tmp) %= MOD;
(f[i+1][2][s1][s2|ns[i+1].s] += tmp) %= MOD;
}
if(cho == 1) (f[i+1][1][s1|ns[i+1].s][s2] += tmp) %= MOD, (f[i+1][1][s1][s2] += tmp) %= MOD;
if(cho == 2) (f[i+1][2][s1][s2|ns[i+1].s] += tmp) %= MOD, (f[i+1][2][s1][s2] += tmp) %= MOD;
}
else {
(f[i+1][0][s1][s2] += tmp) %= MOD;
(f[i+1][1][s1|ns[i+1].s][s2] += tmp) %= MOD;
(f[i+1][2][s1][s2|ns[i+1].s] += tmp) %= MOD;
}
} int ans = 0;
for(int cho = 0; cho < 3; cho++)
for(int s1 = 0; s1 <= all; s1++)
for(int s2 = 0; s2 <= all; s2++)
if(!(s1 & s2)) (ans += f[n][cho][s1][s2]) %= MOD;
printf("%d\n", ans); return 0;
}
[UOJ#129][BZOJ4197][Noi2015]寿司晚宴的更多相关文章
- [BZOJ4197][Noi2015]寿司晚宴
4197: [Noi2015]寿司晚宴 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 412 Solved: 279[Submit][Status] ...
- BZOJ4197 [Noi2015]寿司晚宴 【状压dp】
题目链接 BZOJ4197 题解 两个人选的数都互质,意味着两个人选择了没有交集的质因子集合 容易想到将两个人所选的质因子集合作为状态\(dp\) \(n\)以内质数很多,但容易发现\(\sqrt{n ...
- bzoj4197 [Noi2015]寿司晚宴——状压DP
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4197 首先,两个人选的数都互质可以看作是一个人选了一个数,就相当于选了一个质因数集合,另一个 ...
- UOJ 129/BZOJ 4197 寿司晚宴 状压DP
//By SiriusRen #include <cstdio> #include <algorithm> using namespace std; ; struct Node ...
- 【BZOJ4197】[Noi2015]寿司晚宴 状压DP+分解质因数
[BZOJ4197][Noi2015]寿司晚宴 Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴 ...
- 【BZOJ-4197】寿司晚宴 状压DP
4197: [Noi2015]寿司晚宴 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 694 Solved: 440[Submit][Status] ...
- BZOJ 4197: [Noi2015]寿司晚宴( dp )
N^0.5以内的质数只有8个, dp(i, j, k)表示用了前i个大质数(>N^0.5), 2人选的质数(<=N^0.5)集合分别为j, k时的方案数. 转移时考虑当前的大质数p是给哪个 ...
- BZOJ_4197_[Noi2015]寿司晚宴_状态压缩动态规划
BZOJ_4197_[Noi2015]寿司晚宴_状态压缩动态规划 Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被 ...
- [NOI2015]寿司晚宴 --- 状压DP
[NOI2015]寿司晚宴 题目描述 为了庆祝NOI的成功开幕,主办方为大家准备了一场寿司晚宴. 小G和小W作为参加NOI的选手,也被邀请参加了寿司晚宴. 在晚宴上,主办方为大家提供了n−1种不同的寿 ...
随机推荐
- ubuntu中使用eclipse开发android,logcat显示问题
〜/工作区/ .metadata / .plugins / org.eclipse.core.runtime / .settings / com.android.ide.eclipse.ddms.pr ...
- 继承UIView的初始化 、重绘、以及绘制图片
大家对于UIViewController的生命周期都相当了解了.但是对于继承UIView的子类能做什么,却很少有文章介绍的. 1. -initWithFrame:(CGRect)rect是view指 ...
- 【数据分析 R语言实战】学习笔记 第八章 方差分析与R实现
方差分析泛应用于商业.经济.医学.农业等诸多领域的数量分析研究中.例如商业广告宣传方面,广告效果可能会受广告式.地区规模.播放时段.播放频率等多个因素的影响,通过方差分析研究众多因素中,哪些是主要的以 ...
- sql中保留2位小数
问题: 数据库里的 float momey 类型,都会精确到多位小数.但有时候 我们不需要那么精确,例如,只精确到两位有效数字. 解决: 1. 使用 Round() 函数,如 Round(@num,2 ...
- 自学Spring Boot
简介: Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配 ...
- Cayley凯莱定理——一一对应
定理 过$n$个有标志顶点的树的数目等于$n^{n-2}$. 此定理说明用$n-1$条边将$n$个已知的顶点连接起来的连通图的个数是$n^{n-1}$.也可以这样理解,将n个城市连接起来的树状网络有$ ...
- 火狐浏览器返回不加载JS
火狐浏览器 go(-1),返回后不加载JS,谷歌会加载. 总结: Firefox和Safari在back时不会触发load, ready事件! 解决方法: $(window).unload(funct ...
- postman使用--构建工作流和newman
构建工作流 在使用“Collection Runner”的时候,集合中的请求执行顺序就是请求在Collection中的显示排列顺序.但是,有的时候我们不希望请求按照这样的方式去执行,可能是执行完第一个 ...
- [BZOJ3307]:雨天的尾巴(LCA+树上差分+权值线段树)
题目传送门 题目描述: N个点,形成一个树状结构.有M次发放,每次选择两个点x,y对于x到y的路径上(含x,y)每个点发一袋Z类型的物品.完成所有发放后,每个点存放最多的是哪种物品. 输入格式: 第一 ...
- shell脚本,awk实现文件a的每行数据与文件b的相对应的行的值相减,得到其绝对值。
解题思路 文件 shu 是下面这样的.220 34 50 70553 556 32 211 1 14 98 33 文件 jian是下面这样的.1082 想要得到结果是下面这样的.210 24 40 6 ...