2016 Multi-University Training Contest 1 G. Rigid Frameworks
Rigid Frameworks
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 337 Accepted Submission(s): 273
Maid xiaodao is learning theoretical computer science in her spare time, and recently she was fascinated by Professor Erik Demaine's Geometric Folding Algorithms - Linkages, Origami, Polyhedra. The following problem was inspired by this book.
Recall that a graph is a collection of vertices and edges connecting the vertices, and that two vertices connected by an edge are called adjacent. Graphs can be embedded in Euclidean space by associating each vertex with a point in the Euclidean space.
⋅ A flexible graph is an embedding of a graph where it is possible to move one or more vertices continuously so that the distance between at least two nonadjacent vertices is altered while the distances between each pair of adjacent vertices is kept constant.
⋅ A rigid graph is an embedding of a graph which is not flexible. Informally, a graph is rigid if by replacing the vertices with fully rotating hinges and the edges with rods that are unbending and inelastic, no parts of the graph can be moved independently from the rest of the graph.

Sit down and relax, to simplify the problem, let's only consider the planar graphs as grids. The grid graphs embedded in the Euclidean plane are not rigid, as the following animation demonstrates:

However, one can make them rigid by adding diagonal edges to the cells. For example, the following picture shows a 2 × 3 grid graph.

Note that you can add at most one orientation of a diagonal edge in one single cell. In fact, there are 448 ways to make a 2 × 3 grid graph rigid. And now we want to know, how many different rigid m × n grid graph with diagonal edges in total? Dear contestant, could you please find it out?
3 2
7 9
10 10
448
357533852
935300639
题意:
一个n*m的网格,如题目中图片所示。
所有的点都是交接点,所有的直线都是不可拉伸的铁棍。
这样这个网格是可以活动的。
现在可以在某些网格中在对角线上添加不可拉伸的铁棍。
同一个网格只能添加一次。
这样添加完后,若网格个不可活动,则为稳定。 问,使网格稳定的添边方式有多少种?
题解:
首先,要知道:
1、每一列水平的直线之间是平行的,每一行竖直的直线之间也是平行的。
2、题目要求的稳定,就是要求横着的直线和竖着的直线都垂直。
这里的直线是那一条条小线段,下文中的小直线、直线都是一个意思。 如果我在第(i,j)个格子添加了斜线,
那么第i行的小直线和第j列小直线就必然垂直了。 所以如果我把这n个行作为左边的点,m个列作为右边的点。
添加对角线使它们垂直就相当于在对应点对之间连一条边。
注意这种垂直关系是可以传递的。 所以问题转换成了,是一个左边n个点,右边m个点的二分图,
有多少种方式连边使它们连通。
其中每个点对的连边方式有两种(主对角线、副对角线) 那么这个方式怎么统计?
若是随意连边,总方案数为3^(n*m)种。
因为n*m对边可以连,也可以不连,连有两种,不连一种。 考虑二分图不连通的方案数:
那么至少左边1号点所在的连通快不会包含所有点。 所以只需要枚举1号点所在的连通快大小,
计算出当1号点所在连通块大小为所枚举的时候的方案数就可以了。
枚举时可以枚举1号点所在连通块左边有i个点,右边有j个点。
那么连边方案数就为f[i][j],恰好是个子问题。 所以若令f[n][m]为左边n个点,右边m个点的二分图的连通方案数。
f[n][m] = 3^(n*m) -
sigma(0<=i<n, sigma(0<=j<=m,
f[i + 1][j] * C(n - 1, i) * C(m, j) * 3^( (n-1-i)*(m-j) )
))
const int N = , MOD = 1e9 + ;
int n, m, f[N][N], all[N * N], C[N][N]; inline int add(int x, int y) {
return (((x + y) % MOD) + MOD) % MOD;
} inline int mul(int x, int y) {
return (((x * 1ll * y) % MOD) + MOD) % MOD;
} inline void init() {
all[] = ;
for(int i = ; i < * ; ++i) all[i] = mul(all[i - ], ); for(int i = ; i < N; ++i) C[i][] = ;
for(int i = ; i < N; ++i)
for(int j = ; j < N; ++j)
C[i][j] = add(C[i - ][j - ], C[i - ][j]); for(int n = ; n <= ; ++n)
for(int m = ; m <= ; ++m) {
f[n][m] = all[n * m];
for(int lef = ; lef < n; ++lef)
for(int rig = ; rig <= m; ++rig) {
if(lef == n - && rig == m) continue;
f[n][m] = add(f[n][m],
-mul(mul(mul(C[n - ][lef], C[m][rig]),
f[lef + ][rig]),
all[(n - lef - ) * (m - rig)]));
}
}
} int main() {
init();
while(scanf("%d%d", &n, &m) == ) printf("%d\n", f[n][m]);
return ;
}
2016 Multi-University Training Contest 1 G. Rigid Frameworks的更多相关文章
- 2016 Al-Baath University Training Camp Contest-1 G
Description The forces of evil are about to disappear since our hero is now on top on the tower of e ...
- 2016 Al-Baath University Training Camp Contest-1
2016 Al-Baath University Training Camp Contest-1 A题:http://codeforces.com/gym/101028/problem/A 题意:比赛 ...
- 2016 Al-Baath University Training Camp Contest-1 E
Description ACM-SCPC-2017 is approaching every university is trying to do its best in order to be th ...
- 2016 Al-Baath University Training Camp Contest-1 F
Description Zaid has two words, a of length between 4 and 1000 and b of length 4 exactly. The word a ...
- 2016 Al-Baath University Training Camp Contest-1 A
Description Tourist likes competitive programming and he has his own Codeforces account. He particip ...
- [CFGym101028] 2016 Al-Baath University Training Camp Contest-1
比赛链接:http://codeforces.com/gym/101028/ 由于实习,几乎没有时间刷题了.今天下午得空,断断续续做了这一套题,挺简单的. A.读完题就能出结果. /* ━━━━━┒ギ ...
- 2016 Al-Baath University Training Camp Contest-1 J
Description X is fighting beasts in the forest, in order to have a better chance to survive he's gon ...
- 2016 Al-Baath University Training Camp Contest-1 I
Description It is raining again! Youssef really forgot that there is a chance of rain in March, so h ...
- 2016 Al-Baath University Training Camp Contest-1 H
Description You've possibly heard about 'The Endless River'. However, if not, we are introducing it ...
随机推荐
- mysql中distinct的用法
本事例实验用表task,结构如下 MySQL> desc task; +-------------+------------+------+-----+-------------------+- ...
- CentOS系统IPTables防火墙中FTP规则设置
时间 2016-04-21 10:32:15 虫虫开源 原文 http://www.sijitao.net/2403.html 主题 iptablesFTP防火墙 在设置ftp通过iptables ...
- 怎样在Windows资源管理器中添加右键菜单以及修改右键菜单顺序
有时,我们需要在Windows资源管理器的右键菜单中添加一些项,以方便使用某些功能或程序. 比如我的电脑上有一个免安装版的Notepad++,我想在所有文件的右键菜单中添加一项用Notepad++打开 ...
- Python 网络爬虫(新闻采集脚本)
=====================爬虫原理===================== 通过Python访问新闻首页,获取首页所有新闻链接,并存放至URL集合中. 逐一取出集合中的URL,并访问 ...
- Python: with...as...
with open(path, 'r') as f: Soup = BeautifulSoup(f.read(), 'lxml') titles = Soup.select('ul > li & ...
- linux 文件系统
/ 根目录 /bin 存放着启动时所需要的普通程序.很多程序在启动以后也很有用,它们放在这个目录下是因为它们经常要被其他程序调用 /boot 很多Linux系统把内核映像和其他一些和启动有关的文件都放 ...
- js最详细的基础,jquery 插件最全的教材
一.Js的this,{},[] this是Javascript语言的一个关键字,随着函数使用场合的不同,this的值会发生变化.但是有一个总的原则,那就是this指的是调用的函数自己. { } 大括号 ...
- go:结构体的可访问性
1.要使某个符号对其他包( package)可见(即可以访问),需要将该符号定义为以大写字母开头------摘自go相关书籍2.go只限制包内外的可访问性,而不限制同包内不同文件的可访问性 本文讨论结 ...
- ASCII码、Unicode码 转中文
ASCII码.Unicode码 转中文 在最近工作中遇到了一些汉字编码转换的处理,可以通过正则表达式及转换字符来实现转成中文 Unicode转换示例 通常为10位编码, 通过digit参数传入 pri ...
- 如何写 JS 的链式调用 ---》JS 设计模式《----方法的链式调用
1.以$ 函数为例.通常返回一个HTML元素或一个元素集合. 代码如下: function $(){ var elements = []; ;i<arguments.length;i++){ v ...