【HNOI2015】实验比较
题面
题解
首先将所有相等的用并查集缩点,然后会发现题目有一个很有用的性质:
对每张图片\(i\),小D都最多只记住了某一张质量不比\(i\)差的另一张图片\(K_i\)。
于是将\(K_i\)作为\(i\)的父亲节点,对于\(K_i = 0\)的点,令\(i\)的父亲为\(n + 1\)即可。
开始树形\(dp\),设\(f[x][i]\)表示\(dp\)到点\(x\),有\(i - 1\)个小于号的方案数。
那么我们可以推出一个式子:
\]
其中\(\xi\)是表示\(j\)段和\(k\)段合并成\(i\)段的方案数。
我们考虑如何求余项\(\xi\),设\(f[x]\)的质量序列为\(A\),\(f'[x]\)的质量序列为\(B\),\(f[to]\)的质量序列为\(C\)。
\(A\)的每一段可以只包含\(B\)的一段或者\(C\)的一段,也可以同时包含,但不能为空。特殊地,\(A\)的第一段只能包含节点\(x\)。
于是\(\xi\)相当于先枚举\(B\)中的\(j - 1\)段在\(A\)中放的位置,方案数为\(\binom{i - 1}{j - 1}\),然后将\(C\)的\(i - j\)段放在\(A\)中剩下的位置,使得每一段都不为空。现在\(C\)中还有\(k - i + j\)段要与\(B\)中的段合并,方案数为\(\binom{j - 1}{k - i + j}\)。
于是:
\]
最后答案为\(\sum_{i = 1}^{\mathrm{size}(n + 1)} f[n + 1][i]\)
复杂度:因为每个点对只会在LCA处算\(\mathrm{O}(n)\)次,于是复杂度是\(\mathrm{O}(n^3)\)
代码
#include<cstdio>
#include<cstring>
#include<cctype>
#include<algorithm>
#define RG register
inline int read()
{
int data = 0, w = 1; char ch = getchar();
while(ch != '-' && (!isdigit(ch))) ch = getchar();
if(ch == '-') w = -1, ch = getchar();
while(isdigit(ch)) data = data * 10 + (ch ^ 48), ch = getchar();
return data * w;
}
inline char get()
{
char ch = getchar();
while(ch != '<' && ch != '=') ch = getchar();
return ch;
}
const int N(105), Mod(1e9 + 7), M(100);
struct edge { int next, to; } e[N << 1];
int n, m, X[N], Y[N], fa[N], eq[N], size[N], e_num;
int belong[N], cnt[N], head[N], C[N][N], f[N][N];
int find(int x) { return fa[x] == x ? x : fa[x] = find(fa[x]); }
inline void add_edge(int from, int to)
{
e[++e_num] = (edge) {head[from], to}; head[from] = e_num;
e[++e_num] = (edge) {head[to], from}; head[to] = e_num;
}
inline int merge(int x, int y)
{
int fx = find(x), fy = find(y);
fa[fx] = fy; return fx == fy;
}
void dfs(int x, int _f)
{
static int g[N]; size[x] = f[x][1] = 1;
for(RG int p = head[x]; p; p = e[p].next)
{
int to = e[p].to; if(to == _f) continue;
dfs(to, x); std::fill(g + 1, g + n + 1, 0);
for(RG int i = 1; i <= size[x] + size[to]; i++)
for(RG int j = 1; j <= size[x]; j++)
for(RG int k = 1; k <= size[to]; k++)
{
int t = k - i + j; if(t < 0) continue;
g[i] = (g[i] + 1ll * f[x][j] * f[to][k] % Mod *
C[i - 1][j - 1] % Mod * C[j - 1][t]) % Mod;
}
size[x] += size[to];
std::copy(g + 1, g + size[x] + 1, f[x] + 1);
}
}
int main()
{
C[0][0] = 1;
for(RG int i = 1; i <= M; i++)
{
C[i][0] = C[i][i] = 1;
for(RG int j = 1; j < i; j++)
C[i][j] = (C[i - 1][j] + C[i - 1][j - 1]) % Mod;
}
n = read(), m = read();
for(RG int i = 1; i <= n; i++) fa[i] = i;
for(RG int i = 1; i <= m; i++)
X[i] = read(), eq[i] = get() == '=', Y[i] = read();
for(RG int i = 1; i <= m; i++) if(eq[i]) fa[find(X[i])] = find(Y[i]);
for(RG int i = 1; i <= n; i++) belong[i] = find(i);
for(RG int i = 1; i <= n; i++) fa[i] = i;
for(RG int i = 1; i <= m; i++) if(!eq[i])
{
add_edge(belong[X[i]], belong[Y[i]]), ++cnt[belong[Y[i]]];
if(merge(belong[X[i]], belong[Y[i]])) return puts("0") & 0;
}
for(RG int i = 1; i <= n; i++)
if(belong[i] == i && !cnt[i]) add_edge(n + 1, i);
int ans = 0; dfs(n + 1, 0);
for(RG int i = 1; i <= size[n + 1]; i++)
ans = (ans + f[n + 1][i]) % Mod;
printf("%d\n", ans);
return 0;
}
【HNOI2015】实验比较的更多相关文章
- 【BZOJ4013】[HNOI2015]实验比较(动态规划)
[BZOJ4013][HNOI2015]实验比较(动态规划) 题面 BZOJ 洛谷 题解 看题目意思就是给你一棵树,连边表示强制顺序关系.然后你要给点染色,在满足顺序关系的情况下,将序列染成若干个颜色 ...
- 4013: [HNOI2015]实验比较
4013: [HNOI2015]实验比较 链接 分析: 首先把等号用并查集合并起来. 由于只存在最多一个质量不比i差的数,发现这是森林.若x<y,连边x->y.于是建虚拟根节点0. 然后树 ...
- [BZOJ4013][HNOI2015]实验比较(树形DP)
4013: [HNOI2015]实验比较 Time Limit: 5 Sec Memory Limit: 512 MBSubmit: 756 Solved: 394[Submit][Status] ...
- bzoj 4013: [HNOI2015]实验比较
Description 小D 被邀请到实验室,做一个跟图片质量评价相关的主观实验.实验用到的图片集一共有 N 张图片,编号为 1 到 N.实验分若干轮进行,在每轮实验中,小 D会被要求观看某两张随机选 ...
- [HNOI2015]实验比较
Description 小D 被邀请到实验室,做一个跟图片质量评价相关的主观实验.实验用到的图片集一共有 N 张图片,编号为 1 到 N.实验分若干轮进行,在每轮实验中,小 D会被要求观看某两张随机选 ...
- P3240 [HNOI2015]实验比较 树形DP
\(\color{#0066ff}{ 题目描述 }\) 小D 被邀请到实验室,做一个跟图片质量评价相关的主观实验.实验用到的图片集一共有 \(N\) 张图片,编号为 \(1\) 到\(N\).实验分若 ...
- BZOJ4013 : [HNOI2015]实验比较
首先用并查集将等号缩点,然后拓扑排序判断有没有环,有环则无解,否则通过增加超级源点$0$,可以得到一棵树. 设$f[x][y]$表示$x$子树里有$y$种不同的数字的方案数,由底向上DP. 对于当前点 ...
- luogu P3240 [HNOI2015]实验比较
传送门 首先根据题目条件,题目中如果是=的点可以缩起来,然后\(a<b\)连边\(a\rightarrow b\),而且所有点入度为最多1,那么判掉有环的不合法情况,题目中的依赖关系就是一颗外向 ...
- 【BZOJ】4013: [HNOI2015]实验比较
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=4013 中第i 条涉及的图片对为(KXi, Xi),判断要么是KXi < Xi ,要么 ...
- 【LG3240】[HNOI2015]实验比较
题面 洛谷 题解 30pts 爆搜即可. 100pts 题意描述里有一句:"对每张图片\(i\),小\(D\)都最多只记住了某一张质量不比\(i\)差的另一张图片\(K_i\)." ...
随机推荐
- django项目设计
我们以前是只建立一个项目只建立一个app,如果我们要建立多个app的时候 并且这个app要写很多额视图的函数views内函数,要是建立很多种的时候就会造成很冗杂,不美观 我们未来增强解耦性,就把那个 ...
- springmvc处理日期格式
解决http400错误 通常有两个来源: 1 页面的下拉列表中传入了字符串,而服务器需要的是Integer类型的,所以服务器拒绝. 2, 浏览器传给服务器端的日期格式字符串,服务器端理解不了,所以需要 ...
- TreeMap:是基于红黑树的Map接口的实现
> TreeMap:是基于红黑树的Map接口的实现. 红黑树:平衡二叉树 取出时,可以有三种方式:前序遍历,中序遍历,后序遍历 >排序: A 自然排序 --TreeMap无参构造 Tre ...
- 应用程序-特定 权限设置并未向在应用程序容器 不可用 SID (不可用)中运行的地址 LocalHost (使用 LRPC) 中的用户
这是安装biztalk server 2013出现的问题,很多天了没解决,下边这个解决办法也搜到过类似的,但上次实验时出现设置组件权限时发现都是按钮都是灰的,无法操作. 这次设置好了.谢谢ibg. 文 ...
- 17:54 思维导图coggle布置好了
钱不是好赚的,要赚钱就要冒险,就会有损失.为了家庭还是旱涝保收一点好,没有现金流什么都是白搭,通过博客来学习也是件不错的是,问题是我现在完全没有想法,比如冒泡算法什么的,没有概念,背不出来,其实可以推 ...
- 【原创】由于python的导入方式引起的深坑
目录结构: test/ sacc/ __init__.py app.py logger.py /views __init__.py main.py 事情是这样的,logger里面是一个类LoggerF ...
- bootstrap-multiselect样式修改
问题 bootstrap-multiselect是一款相当不错的bootstrap风格下拉框组件,但是它的某些样式我不是很喜欢,按钮文本和下拉符号 “” 都是居中的,且下拉列表的宽度也没有跟随变动. ...
- 看懂shebang吧,只需一点点shell知识,从此再也不犯强迫症
Python2: 开启一个terminal,输入下面命令: yshuangj@ubuntu:~$ vim helloA.py 在vim编辑器中,进入编辑模式(按i),输入下面的代码,然后退出编辑模式( ...
- mycat结合双主复制实现读写分离模式
简介:应用程序仅需要连接mycat,后端服务器的读写分离由mycat进行控制,后端服务器数据的同步由MySQL主从同步进行控制. 本次实验环境架构图 服务器主机规划 主机名 IP 功能 备注 lin ...
- [AHOI2005]矿藏编码
嘟嘟嘟 这道题题面我是看了小半天才懂(太菜了),然后就发现好水啊. 只要维护一个栈,存的是t,代表当前的正方形是2t * 2t的,然后从头开始扫序列,如果遇到2,就把栈顶元素取出来,然后放进去四个t ...