Pagini recente » Cod sursa (job #2571809) | Cod sursa (job #2315477) | Cod sursa (job #2831015) | Cod sursa (job #2782266) | Cod sursa (job #3224978)
#include <fstream>
#include <vector>
using namespace std;
ifstream cin("dfs.in");
ofstream cout("dfs.out");
void dfs(int current_node, vector<vector<int>>& adj, vector<bool>& visited) {
visited[current_node] = 1;
for (int i = 0; i < adj[current_node].size(); ++i) {
if (!visited[adj[current_node][i]])
dfs(adj[current_node][i], adj, visited);
}
}
int main() {
int n, m;
cin >> n >> m;
vector<vector<int>> adj(n);
for (int i = 0; i < m; ++i) {
int x, y;
cin >> x >> y;
adj[x].push_back(y);
adj[y].push_back(x);
}
vector<bool> visited(n, false);
int conexe = 0;
for (int i = 0; i < n; ++i)
if (!visited[i]) {
dfs(i, adj, visited);
++conexe;
}
cout << conexe << endl;
}