Pagini recente » Cod sursa (job #9776) | Cod sursa (job #1095625) | Cod sursa (job #1089935) | Cod sursa (job #1669378) | Cod sursa (job #2522735)
#include <iostream>
#include <fstream>
#include <vector>
#include <queue>
#include <algorithm>
#include <string.h>
#include <stdio.h>
using namespace std;
ifstream in("dfs.in");
ofstream out("dfs.out");
const int MAXN = 100005;
int n, m, x, y, answer;
vector <int> d[MAXN];
bool viz[MAXN];
void read(){
in >> n >> m;
for(int i = 0; i < m; ++i){
in >> x >> y;
d[x].push_back(y);
d[y].push_back(x);
}
}
void dfs(int nod){
viz[nod] = true;
for(int i = 0; i < d[nod].size(); ++i){
int nextnod = d[nod][i];
if(!viz[nextnod]){
dfs(nextnod);
}
}
}
void show(){
out << answer << '\n';
}
int main(){
read();
memset(viz, false, sizeof(viz));
for(int i = 1; i <= n; i++){
if(!viz[i]){
answer +=1;
dfs(i);
}
}
show();
return 0;
}