1. #include <bits/stdc++.h>
  2. using namespace std;
  3. #define int long long
  4. const int N = 20;
  5. const int mod = 1e+9 + 7;
  6. namespace mat {
  7. int a[N][N];
  8. int n,p=1;
  9. void Clear() {
  10. memset(a,0,sizeof a);
  11. }
  12. int Solve() {
  13. int ans = 1;
  14. for(int i = 1; i < n; i ++) {
  15. for(int j = i + 1; j < n; j ++)
  16. while(a[j][i]) {
  17. int t = a[i][i] / a[j][i];
  18. for(int k = i; k < n; k ++)
  19. a[i][k] = (a[i][k] - t * a[j][k] + mod) % mod;
  20. swap(a[i], a[j]);
  21. ans = - ans;
  22. }
  23. ans = (ans * a[i][i]) % mod;
  24. }
  25. return (ans + mod) % mod;
  26. }
  27. void Make(int p,int q) {
  28. a[p][q]--;
  29. a[q][p]--;
  30. a[p][p]++;
  31. a[q][q]++;
  32. }
  33. } // namespace mat
  34. int n;
  35. vector <pair<int,int> > v[N];
  36. signed main() {
  37. ios::sync_with_stdio(false);
  38. cin>>n;
  39. for(int i=1;i<n;i++) {
  40. int t;
  41. cin>>t;
  42. for(int j=1;j<=t;j++) {
  43. int t1,t2;
  44. cin>>t1>>t2;
  45. v[i].push_back(make_pair(t1,t2));
  46. }
  47. }
  48. int ans = 0;
  49. mat::n=n;
  50. for(int i=0;i<1<<(n-1);i++) {
  51. int t=__builtin_popcount(i);
  52. mat::Clear();
  53. for(int j=1;j<=(n-1);j++) {
  54. if(i&(1<<(j-1))) {
  55. for(int k=0;k<v[j].size();k++) {
  56. mat::Make(v[j][k].first, v[j][k].second);
  57. }
  58. }
  59. }
  60. int tmp = mat::Solve();
  61. ans += ((n-t-1)%2 ? -1 : 1)*tmp;
  62. ans %= mod;
  63. ans += mod;
  64. ans %= mod;
  65. }
  66. cout<<ans<<endl;
  67. }

[SHOI2016] 黑暗前的幻想乡 - 矩阵树定理,容斥的更多相关文章

  1. bzoj 4596 [Shoi2016]黑暗前的幻想乡 矩阵树定理+容斥

    4596: [Shoi2016]黑暗前的幻想乡 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 559  Solved: 325[Submit][Sta ...

  2. bzoj4596/luoguP4336 [SHOI2016]黑暗前的幻想乡(矩阵树定理,容斥)

    bzoj4596/luoguP4336 [SHOI2016]黑暗前的幻想乡(矩阵树定理,容斥) bzoj Luogu 题解时间 看一看数据范围,求生成树个数毫无疑问直接上矩阵树定理. 但是要求每条边都 ...

  3. Luogu P4336 [SHOI2016]黑暗前的幻想乡 矩阵树定理+容斥原理

    真是菜到爆炸....容斥写反(反正第一次写qwq) 题意:$n-1$个公司,每个公司可以连一些边,求每个边让不同公司连的生成树方案数. 矩阵树定理+容斥原理(注意到$n$不是很大) 枚举公司参与与否的 ...

  4. 【BZOJ4596】【Luogu P4336】 [SHOI2016]黑暗前的幻想乡 矩阵树定理,容斥

    同样是矩阵树定理的裸题.但是要解决它需要能够想到容斥才可以. \(20\)以内的数据范围一定要试试容斥的想法. #include <bits/stdc++.h> using namespa ...

  5. P4336 [SHOI2016]黑暗前的幻想乡

    P4336 [SHOI2016]黑暗前的幻想乡 矩阵树定理(高斯消元+乘法逆元)+容斥 ans=总方案数 -(公司1未参加方案数 ∪ 公司2未参加方案数 ∪ 公司3未参加方案数 ∪ ...... ∪ ...

  6. 【BZOJ 4596】 4596: [Shoi2016]黑暗前的幻想乡 (容斥原理+矩阵树定理)

    4596: [Shoi2016]黑暗前的幻想乡 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 324  Solved: 187 Description ...

  7. 【BZOJ4596】[Shoi2016]黑暗前的幻想乡 容斥+矩阵树定理

    [BZOJ4596][Shoi2016]黑暗前的幻想乡 Description 幽香上台以后,第一项措施就是要修建幻想乡的公路.幻想乡有 N 个城市,之间原来没有任何路.幽香向选民承诺要减税,所以她打 ...

  8. [ZJOI2016]小星星&[SHOI2016]黑暗前的幻想乡(容斥)

    这两道题思路比较像,所以把他们放到一块. [ZJOI2016]小星星 题目描述 小Y是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有n颗小星星,用m条彩色的细线串了起来,每条细线连着两颗小星星. ...

  9. bzoj4596[Shoi2016]黑暗前的幻想乡 Matrix定理+容斥原理

    4596: [Shoi2016]黑暗前的幻想乡 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 464  Solved: 264[Submit][Sta ...

随机推荐

  1. bootstrap234的ie兼容选择

    如果你需要兼容IE8甚至是IE7和IE6,那么只能选择Bootstrap2,虽然它自身在IE6的效果也并不完美.如果需要兼容IE678的话用2.如果需要高版本的浏览器,并且移动端优先的话,那么用boo ...

  2. LOJ #2831. 「JOISC 2018 Day 1」道路建设 线段树+Link-cut-tree

    用 LCT 维护颜色相同连通块,然后在线段树上查一下逆序对个数就可以了. code: #include <cstdio> #include <algorithm> #inclu ...

  3. 配置 vim 过程中必须解决的问题

    网络问题 在使用 github 作为插件下载源的时候, 容易出现网络连接超时等错误 在使用 gitee 作为插件下载源的时候, 子模块可能会出现下载超时 解决方案有以下两个: 使用 VPN , 改善访 ...

  4. WebApp开发-Zepto

    zepto.js自己去官网下载哈. DOM操作 $(document).ready(function(){ var $cr = $("<div class='cr'>插入的div ...

  5. 在Django中使用Sentry(Python 3.6.8 + Django 1.11.20 + sentry-sdk 0.13.5)

    1. 安装Sentry pip install sentry-sdk==0.13.5 2.在settings.py中配置 sentry_sdk.init( dsn="https://**** ...

  6. gulp常用插件之gulp-rev-format使用

    更多gulp常用插件使用请访问:gulp常用插件汇总 gulp-rev-format这是一款提供静态资产的哈希格式选项(前缀,后缀,最后扩展名). 更多使用文档请点击访问gulp-rev-format ...

  7. 16G内存,将内存占用,降到了 40% 以下,之前是 90%+

    自定义组件:

  8. BurpSuite 汉化版(含注册机)安装教程

      1.注册机使用方法 首先需要完成java安装及环境变量配置. 打开burp-loader-keygen.jar(注册机)--点击run--license text (随意写)--然后将生成的lic ...

  9. WPF实现高仿统计标题卡

    飘哇~~~,在家数瓜子仁儿,闲来无事,看东看西,也找点儿,最近正在看看WPF动画,光看也是不行,需要带着目的去学习,整合知识碎片,恰巧,看到Github中一个基于Ant Designer设计风格的后台 ...

  10. JS 字符串 String对象

    charAt(index) 返回指定索引位置的字符 charCodeAt() 返回指定索引位置字符的 Unicode 值 indexOf(searchString, startIndex) 返回子字符 ...