只要有一个环的连通分支,那么肯定可以做到环内的点都有入度,对于环外的点可以看成DFS遍历的生成树的节点,肯定可以有一条有向的通路,
通路上的点都有入度,这个连通分支可以做到最少为0个没有入度的点
如果没有环的连通分支,那么只需要找一个点作为生成树的根节点,那么就可以做到最少只有1个点没有入度
#include <cstdio>
#include <cstring>
#include <iostream>
#include <vector>
using namespace std;
const int maxn = 100000 + 10;
vector<int> G[maxn];
bool vis[maxn], flag;
int n, m, ans;
void dfs(int s, int pre) {
vis[s] = true;
for (int i = 0; i < G[s].size(); i++) {
if (vis[G[s][i]] && G[s][i] != pre) {
flag = true;
}
else if (!vis[G[s][i]]) {
dfs(G[s][i], s);
}
}
}
int main()
{
scanf("%d%d", &n, &m);
for (int i = 0; i < m; i++) {
int u, v;
scanf("%d%d", &u, &v);
G[u].push_back(v);
G[v].push_back(u);
}
memset(vis, false, sizeof(vis));
ans = 0;
for (int i = 1; i <= n; i++) {
if (!vis[i]) {
flag = false;
dfs(i, i);
if (!flag) ans++;
}
}
printf("%d\n", ans);
return 0;
}