Pagini recente » Monitorul de evaluare | Cod sursa (job #308739) | Cod sursa (job #3213269) | Cod sursa (job #1123404) | Cod sursa (job #3286796)
#include<fstream>
#include<vector>
using namespace std;
ifstream cin("dfs.in");
ofstream cout("dfs.out");
vector<int>v[100001];
int a,b,cont,n,m;
bool viz[100001];
void dfs(int k){
viz[k]=1;
for(int i=0;i<v[k].size();i++){
if(!viz[v[k][i]])
dfs(v[k][i]);
}
}
int main()
{
cin>>n>>m;
for(int i=1;i<=m;i++){
cin>>a>>b;
v[a].push_back(b);
v[b].push_back(a);
}
for(int i=1;i<=n;i++){
if(!viz[i]){
cont++;
dfs(i);
}
}
cout<<cont;
return 0;
}