codeforces 156D Clues

题意

给定一个无向图,不保证联通。求添加最少的边使它联通的方案数。

题解

根据prufer序列,带标号无根树的方案数是\(n^{n-2}\)

依这个思想构建树即可。

代码

#include<bits/stdc++.h>
using namespace std;
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define rep(i, a, b) for(int i=(a); i<(b); i++)
#define sz(a) (int)a.size()
#define de(a) cout << #a << " = " << a << endl
#define dd(a) cout << #a << " = " << a << " "
#define all(a) a.begin(), a.end()
#define endl "\n"
typedef long long ll;
typedef pair<int, int> pii;
typedef vector<int> vi;
//--- const int N = 101010; int n, m, p;
int pre[N], cnt[N]; int find(int x) {
if(x == pre[x]) return x;
return pre[x] = find(pre[x]);
}
void join(int x, int y) {
x = find(x);
y = find(y);
pre[x] = y;
} int main() {
std::ios::sync_with_stdio(false);
std::cin.tie(0);
cin >> n >> m >> p;
rep(i, 1, n+1) pre[i] = i;
rep(i, 0, m) {
int u, v;
cin >> u >> v;
join(u, v);
}
rep(i, 1, n+1) ++cnt[find(i)];
ll ans = 1;
int c = 0;
rep(i, 1, n+1) if(cnt[i]) {
ans = ans * cnt[i] % p;
++c;
}
rep(i, 0, c-2) ans = ans * n % p;
if(c == 1) ans = 1 % p;
cout << ans << endl;
return 0;
}

最新文章

  1. JavaScript闭包之“词法作用域”
  2. Java RandomAccessFile用法
  3. Maven-009-Nexus 用户密码加密(安全必须)
  4. 解析工具Goson
  5. CoreLoation
  6. 时间c#
  7. [quote ]ffmpeg, gstreamer, Raspberry Pi, Windows Desktop streaming
  8. 为什么主流网站无法捕获 XSS 漏洞?
  9. Majority Element II——LeetCode
  10. hibou 主界面自己侧滑的定义
  11. ThinkPHP第五天(提交类型判定常量IS_POST等,错误页面种类,Model实例化方式,模板中使用函数,foreach循环,模板中.语法配置)
  12. Android TextView里直接显示图片的三种方法
  13. screen 链接远程桌面
  14. input元素之间的融合
  15. table之thead兼容
  16. 转:聚类、K-Means、例子、细节
  17. linux 显示当前所在文件位置 以及git 分支所在
  18. ActiveMQ简单使用
  19. Linux - 7种运行级别
  20. mysql5.7报err 1055错误 sql_mode=only_full_group_by

热门文章

  1. spring 线程异步执行
  2. JAVA练手--String
  3. java并发编程(10)Fork/Join
  4. Postgresql 连接更新
  5. WCF-终结点之消息路由示例
  6. unity TileMap 简述
  7. Android Studio中 图片资源存在但是运行时报错的问题
  8. hdu 3415 Max Sum of Max-K-sub-sequence 单调队列。
  9. ORACLE-DataGuard-重启服务器的方法
  10. [SHOI2007]园丁的烦恼