题解
题目大意 给你n个点使用m条边组成一个图 问你最多和最小能有多少个孤立节点(度为0)
最少的点个数就是每个边连两个点m-n2和0取max
最多的点计算d(d-1)=m*2用n-d 需要特判0
AC代码
#include <stdio.h>
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int INF = 0x3f3f3f3f;
int main()
{
#ifdef LOCAL
//freopen("C:/input.txt", "r", stdin);
#endif
ll n, m;
cin >> n >> m;
ll d;
for (d = 0; d * (d + 1) <= m * 2; d++);
cout << max(0LL, n - m * 2) << " " << n - d - 1 + (d * (d - 1) == m * 2) + (m == 0) << endl;
return 0;
}
本文探讨了一个图论问题,通过给定的点和边数量,计算在一个图中可能存在的最大和最小孤立节点数量。文章提供了详细的解析思路,并附带了AC代码实现,帮助读者理解并解决类似问题。
1292

被折叠的 条评论
为什么被折叠?



