AT_abc350_d 题解
个人认为 C>D。
思路
首先对于每个连通块,我们尽量让它们都变成完全图。然后判连通块可以用并查集,也可以用 BFS,本人用了并查集。注意最后要减去现有的 条边。
代码
# include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair <int, int> pii;
int n, f[200005], q, x, y, s[200005];
ll sum;
int find (int x) {
return x == f[x] ? x : f[x] = find (f[x]);
}
int main () {
ios::sync_with_stdio (0);
cin.tie (0);
cout.tie (0);
cin >> n >> q;
for (int i = 1; i <= n; ++ i)
f[i] = i;
sum = -q;
while (q --) {
cin >> x >> y;
f[find (x)] = find (y);
}
for (int i = 1; i <= n; ++ i)
++ s[find (i)];
for (int i = 1; i <= n; ++ i)
if (s[i])
sum += s[i] * (s[i] - 1ll) / 2;
cout << sum;
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
· 为什么 退出登录 或 修改密码 无法使 token 失效