BZOJ 1016 最小生成树计数
Description
现在给出了一个简单无向加权图。你不满足于求出这个图的最小生成树,而希望知道这个图中有多少个不同的最小生成树。(如果两颗最小生成树中至少有一条边不同,则这两个最小生成树就是不同的)。由于不同的最小生成树可能很多,所以你只需要输出方案数对31011的模就可以了。
Input
第一行包含两个数,n和m,其中1<=n<=100; 1<=m<=1000; 表示该无向图的节点数和边数。每个节点用1~n的整数编号。接下来的m行,每行包含两个整数:a, b, c,表示节点a, b之间的边的权值为c,其中1<=c<=1,000,000,000。数据保证不会出现自回边和重边。注意:具有相同权值的边不会超过10条。
Output
输出不同的最小生成树有多少个。你只需要输出数量对31011的模就可以了。
Sample Input
1 2 1
1 3 1
1 4 1
2 3 2
2 4 1
3 4 1
Sample Output
HINT
Source
这题要猜一个结论——长为i的边个数是一定的以及前i小的边他们构成的并查集是一定的,这样就可以 2^n dfs了(相同长度的边<=10)。
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<cstdlib>
using namespace std; #define maxn (110)
#define maxm (1010)
#define rhl (31011) int father[maxn],save[maxn],bac[maxm],road[maxm];
int n,m,tot,ans,sum;
struct E{ int u,v,w; }edge[maxm]; inline void init() {for (int i = ;i <= n;++i) father[i] = i;} inline int find(int a) {if (father[a] != a) father[a] = find(father[a]); return father[a];} inline bool cmp(E a,E b){ return a.w < b.w; } inline void mst()
{
sort(edge+,edge+m+,cmp); init();
int have = ,r1,r2,pos;
for (int i = ;i <= m;++i)
{
r1 = find(edge[i].u),r2 = find(edge[i].v);
if (r1 != r2)
{
father[r1] = r2; ++have;
pos = lower_bound(bac+,bac+tot+,edge[i].w)-bac;
++road[pos];
}
if (have == n - ) break;
}
if (have < n - ) printf(""),exit();
} inline void dfs(int a,int r,int pos,int cho)
{
if (road[pos] == cho)
{
++sum;
if (sum == ) memcpy(save,father,sizeof(save));
return;
}
if (a > r) return;
if (cho+r-a+<road[pos]) return;
int temp[maxn];
dfs(a+,r,pos,cho);
memcpy(temp,father,sizeof(temp));
int r1 = find(edge[a].u),r2 = find(edge[a].v);
if (r1 != r2) father[r1] = r2,dfs(a+,r,pos,cho+);
memcpy(father,temp,sizeof(temp));
} int main()
{
freopen("1016.in","r",stdin);
freopen("1016.out","w",stdout);
scanf("%d %d",&n,&m);
for (int i = ;i <= m;++i)
{
int a,b,c;
scanf("%d %d %d",&a,&b,&c);
edge[i] = (E) {a,b,c};
bac[i] = c;
}
sort(bac+,bac+m+);
tot = unique(bac+,bac+m+)-bac-;
mst();
init(); ans = ;
for (int i = ;i <= m;)
{
int j = i;
while (j < m && edge[j+].w == edge[i].w) ++j;
sum = ;
dfs(i,j,lower_bound(bac+,bac+tot,edge[i].w)-bac,);
(ans *= sum)%=rhl;
memcpy(father,save,sizeof(save));
i = j+;
}
printf("%d",ans);
fclose(stdin); fclose(stdout);
return ;
}
BZOJ 1016 最小生成树计数的更多相关文章
- BZOJ 1016 最小生成树计数 【模板】最小生成树计数
[题解] 对于不同的最小生成树,每种权值的边使用的数量是一定的,每种权值的边的作用是确定的 我们可以先做一遍Kruskal,求出每种权值的边的使用数量num 再对于每种权值的边,2^num搜索出合法使 ...
- BZOJ 1016 最小生成树计数(矩阵树定理)
我们把边从小到大排序,然后依次插入一种权值的边,然后把每一个联通块合并. 然后当一次插入的边不止一条时做矩阵树定理就行了.算出有多少种生成树就行了. 剩下的交给乘法原理. 实现一不小心就会让程序变得很 ...
- BZOJ 1016--[JSOI2008]最小生成树计数(kruskal&搜索)
1016: [JSOI2008]最小生成树计数 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 7429 Solved: 3098[Submit][St ...
- BZOJ 1016 生成树计数
现在给出了一个简单无向加权图.你不满足于求出这个图的最小生成树,而希望知道这个图中有多少个不同的最小生成树.(如果两颗最小生成树中至少有一条边不同,则这两个最小生成树就是不同的).由于不同的最小生成树 ...
- 【BZOJ】【1016】【JSOI2008】最小生成树计数
Kruskal/并查集+枚举 唉我还是too naive,orz Hzwer 一开始我是想:最小生成树删掉一条边,再加上一条边仍是最小生成树,那么这两条边权值必须相等,但我也可以去掉两条权值为1和3的 ...
- [BZOJ 1016] [JSOI2008] 最小生成树计数 【DFS】
题目链接:BZOJ - 1016 题目分析 最小生成树的两个性质: 同一个图的最小生成树,满足: 1)同一种权值的边的个数相等 2)用Kruscal按照从小到大,处理完某一种权值的所有边后,图的连通性 ...
- BZOJ 1016: [JSOI2008]最小生成树计数( kruskal + dfs )
不同最小生成树中权值相同的边数量是一定的, 而且他们对连通性的贡献是一样的.对权值相同的边放在一起(至多10), 暴搜他们有多少种方案, 然后乘法原理. ----------------------- ...
- 最小生成树的边的概念问题!!! 最小生成树的计数 bzoj 1016
1016: [JSOI2008]最小生成树计数 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 5292 Solved: 2163[Submit][St ...
- 【BZOJ 1016】 1016: [JSOI2008]最小生成树计数 (DFS|矩阵树定理)
1016: [JSOI2008]最小生成树计数 Description 现在给出了一个简单无向加权图.你不满足于求出这个图的最小生成树,而希望知道这个图中有多少个不同的最小生成树.(如果两颗最小生成树 ...
随机推荐
- ServerVersion 引发了“System.InvalidOperationException”类型的异常
遇到这样一个问题:添加互评信息,断点调试,跳转到BLL层后就直接跳到SqlHelper中弹出错误,说:未将对象设置引用到实例等.还请人帮忙调试代码,调试半天发现抽象工厂并没成功完成反射,奇怪的是:将出 ...
- dreamvc框架(一)ioc容器的集成
我的dreamvc框架最终写得差点儿相同了,借鉴了非常多开源框架,SpringMVC.Struts2等,眼下放在github上面.地址请猛戳我 写得差点儿相同了,是要写一个总结,把自己当时的思路记录下 ...
- [RxJS] Filtering operator: filter
This lesson introduces filter: an operator that allows us to let only certain events pass, while ign ...
- HDU-4041-Eliminate Witches! (11年北京网络赛!!)
Eliminate Witches! Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- 关于css中伪类及伪元素的总结
css中的伪类和伪元素总是混淆,今天参考了很多资料,也查看了部分文档,现将伪类及伪元素总结如下: 一.由来: 伪类和伪元素的引入都是因为在文档树里有些信息无法被充分描述,比如CSS没有"段落 ...
- HTML5移动开发中的input输入框类型
HTML5规范引入了许多新的input输入框类型 在HTML5移动开发中,通过这些新的输入框类型来显示定制后的键盘布局,用户体验更好,更容易填写各种表单 本文中,实测手机为肾4S与米4 数字类型num ...
- 巧用hidden传递参数
- <input value="hidden">的作用
这样子上个页面的参数可以保存在这个页面,为下个页面获取参数做准备,在这个页面表单提交的时候下个页面可以获取参数
- 脚本动态监控input
Jquery $('input').bind('input propertychange', function() { //进行相关操作 }); JS if(isIE) { document.getE ...
- HTML5 <Audio>标签API整理(一)
简单实例: <audio id="myAudio"></audio> <script> var myAudio = document.getEl ...