1016: [JSOI2008]最小生成树计数

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,0
00。数据保证不会出现自回边和重边。注意:具有相同权值的边不会超过10条。

Output

  输出不同的最小生成树有多少个。你只需要输出数量对31011的模就可以了。

Sample Input

4 6
1 2 1
1 3 1
1 4 1
2 3 2
2 4 1
3 4 1

Sample Output

8

HINT

Source

【分析】

  不知道结论是不可以做的吧?表示也不会矩阵树定理。。dfs方法也要知道一些证明才能说明其准确性。

  【以后的博客都要留坑了?

  安利两种题解:

  1、我的打法:(不看都不知道为什么这样做是对的)

  https://blog.sengxian.com/solutions/bzoj-1016

  http://www.cnblogs.com/lcf-2000/p/5575412.html

  2、矩阵树(没打这种,还不会)

  http://blog.csdn.net/jarily/article/details/8902509

  1. #include<cstdio>
  2. #include<cstdlib>
  3. #include<cstring>
  4. #include<iostream>
  5. #include<algorithm>
  6. using namespace std;
  7. #define Maxn 1100
  8. #define Maxm 10100
  9. #define Mod 31011
  10.  
  11. struct node
  12. {
  13. int x,y,c;
  14. }t[Maxm];
  15.  
  16. bool cmp(node x,node y) {return x.c<y.c;}
  17. int a[Maxm],l[Maxm],r[Maxm],fa[Maxn];
  18.  
  19. int ffa(int x)
  20. {
  21. return x==fa[x]?x:ffa(fa[x]);
  22. }
  23.  
  24. int ct;
  25. void ffind(int x,int nw,int h)
  26. {
  27. if(nw==r[x]+)
  28. {
  29. if(h==a[x]) ct++;
  30. return;
  31. }
  32. int x1=ffa(t[nw].x),x2=ffa(t[nw].y);
  33. if(x1!=x2)
  34. {
  35. fa[x1]=x2;
  36. ffind(x,nw+,h+);
  37. fa[x1]=x1;
  38. }
  39. ffind(x,nw+,h);
  40. }
  41.  
  42. int main()
  43. {
  44. int n,m;
  45. scanf("%d%d",&n,&m);
  46. for(int i=;i<=m;i++)
  47. {
  48. scanf("%d%d%d",&t[i].x,&t[i].y,&t[i].c);
  49. }
  50. sort(t+,t++m,cmp);
  51. int cnt=,tot=;
  52. for(int i=;i<=n;i++) fa[i]=i;
  53. for(int i=;i<=m;i++)
  54. {
  55. if(i==||t[i].c!=t[i-].c)
  56. {
  57. r[cnt]=i-;l[++cnt]=i;
  58. a[cnt]=;
  59. }
  60. int x1=ffa(t[i].x),x2=ffa(t[i].y);
  61. if(x1!=x2)
  62. {
  63. fa[x1]=x2;
  64. a[cnt]++;
  65. tot++;
  66. }
  67.  
  68. }r[cnt]=m;
  69. if(tot!=n-) printf("0\n");
  70. else
  71. {
  72. for(int i=;i<=n;i++) fa[i]=i;
  73. int ans=;
  74. for(int i=;i<=cnt;i++)
  75. {
  76. ct=;
  77. ffind(i,l[i],);
  78. ct%=Mod;
  79. ans=ans*ct;ans%=Mod;
  80. for(int j=l[i];j<=r[i];j++)
  81. {
  82. int x1=ffa(t[j].x),x2=ffa(t[j].y);
  83. if(x1!=x2) fa[x1]=x2;
  84. }
  85. }
  86. printf("%d\n",ans);
  87. }
  88. return ;
  89. }

2017-02-28 13:58:04

【BZOJ 1016】 1016: [JSOI2008]最小生成树计数 (DFS|矩阵树定理)的更多相关文章

  1. bzoj1016 [JSOI2008]最小生成树计数——Kruskal+矩阵树定理

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1016 从 Kruskal 算法的过程来考虑产生多种方案的原因,就是边权相同的边有一样的功能, ...

  2. 洛谷4208 JSOI2008最小生成树计数(矩阵树定理+高斯消元)

    qwq 这个题目真的是很好的一个题啊 qwq 其实一开始想这个题,肯定是无从下手. 首先,我们会发现,对于无向图的一个最小生成树来说,只有当存在一些边与内部的某些边权值相同的时候且能等效替代的时候,才 ...

  3. BZOJ 1016 最小生成树计数(矩阵树定理)

    我们把边从小到大排序,然后依次插入一种权值的边,然后把每一个联通块合并. 然后当一次插入的边不止一条时做矩阵树定理就行了.算出有多少种生成树就行了. 剩下的交给乘法原理. 实现一不小心就会让程序变得很 ...

  4. BZOJ 2467: [中山市选2010]生成树(矩阵树定理+取模高斯消元)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2467 题意: 思路:要用矩阵树定理不难,但是这里的话需要取模,所以是需要计算逆元的,但是用辗转相减会 ...

  5. 【BZOJ 1016】 [JSOI2008]最小生成树计数(matrix-tree定理做法)

    [题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1016 [题意] [题解] /* 接上一篇文章; 这里用matrix-tree定理搞最小 ...

  6. 【BZOJ 1016】[JSOI2008]最小生成树计数(搜索+克鲁斯卡尔)

    [题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1016 [题意] [题解] /* 两个最小生成树T和T'; 它们各个边权的边的数目肯定是 ...

  7. [bzoj1016][JSOI2008]最小生成树计数 (Kruskal + Matrix Tree 定理)

    Description 现在给出了一个简单无向加权图.你不满足于求出这个图的最小生成树,而希望知道这个图中有多少个不同的最小生成树.(如果两颗最小生成树中至少有一条边不同,则这两个最小生成树就是不同的 ...

  8. BZOJ 4031: [HEOI2015]小Z的房间 [矩阵树定理 行列式取模]

    http://www.lydsy.com/JudgeOnline/problem.php?id=4031 裸题........ 问题在于模数是$10^9$ 我们发现消元的目的是让一个地方为0 辗转相除 ...

  9. BZOJ 4031: [HEOI2015]小Z的房间 (矩阵树定理 板题)

    背结论 : 度-邻 CODE1 O(n3logn)O(n^3logn)O(n3logn) #include <bits/stdc++.h> using namespace std; typ ...

随机推荐

  1. json格式的一些常用操作方法

    package com.liveyc.restfull.until; import java.util.HashMap; import java.util.Iterator; import java. ...

  2. Vue 脱坑记

    问题汇总 Q:安装超时(install timeout) 方案有这么些: cnpm : 国内对npm的镜像版本 /* cnpm website: https://npm.taobao.org/ */ ...

  3. perl6 一个猜测密码的注入

    use HTTP::UserAgent; my $ua = HTTP::UserAgent.new; my $r = HTTP::Request.new; my $c = HTTP::Cookies. ...

  4. 76.ZYNQ-用PS控制DDR3内存读写

    本编文章的目的主要用简明的方法对DDR3进行读写,当然这种方式每次读写都需要CPU干预,效率是比较低的,但是这是学习的过程吧. 本系列文章尽可能的让每一个实验都相对独立,过程尽可能保证完整性,保证实验 ...

  5. python基础===数据伪造模块faker

    介绍文档: https://pypi.org/project/Faker/ https://faker.readthedocs.io/en/latest/ https://faker.readthed ...

  6. 【转载】如何解决failed to push some refs to git

    在使用git 对源代码进行push到gitHub时可能会出错,信息如下   此时很多人会尝试下面的命令把当前分支代码上传到master分支上. $ git push -u origin master ...

  7. Deep Learning基础--各个损失函数的总结与比较

    损失函数(loss function)是用来估量你模型的预测值f(x)与真实值Y的不一致程度,它是一个非负实值函数,通常使用L(Y, f(x))来表示,损失函数越小,模型的鲁棒性就越好.损失函数是经验 ...

  8. C++中stringstream样例

    包含头文件 #include <sstream> 初始化可以使用 clear(). str( ) 赋值: 这里的clear方法,实际上是清空stringstream的状态(比如出错等),清 ...

  9. 链接 DB App.config 解析

    <?xml version="1.0" encoding="utf-8"?><configuration> <startup> ...

  10. Sublime Text2使用规则

    Sublime Text是我发现的有一好用的编辑器,它不单单只支持 python ,几乎支持目前主流的语言,快捷键丰富,可以极大的提高代码开发效率.Sublime Text 网址:http://www ...