Pagini recente » Cod sursa (job #2398345) | Cod sursa (job #477756) | Cod sursa (job #1567022) | Cod sursa (job #1069188) | Cod sursa (job #2535722)
#include <iostream>
#include <fstream>
#include <map>
#include <queue>
#define MAX 100001
using namespace std;
ifstream ci ("dfs.in");
ofstream co ("dfs.out");
vector <int>NOD[MAX];
map<pair<int,int>,bool>c;
queue <int>Q;
map<int,bool>viz;
int n,m;
int x,y;
void DFS (int x)
{
viz[x]=true;
for (int i=0;i<NOD[x].size();++i)
{
if (viz[NOD[x][i]]==false)
{
DFS(NOD[x][i]);
}
}
}
int main ()
{
ci>>n>>m;
while (m)
{
m--;
ci>>x>>y;
if (c[make_pair(x,y)]==false)
{
c[make_pair(x,y)]=true;
c[make_pair(y,x)]=true;
NOD[x].push_back(y);
NOD[y].push_back(x);
}
}
int temp=0;
for (int i=1;i<=n;++i)
{
if (viz[i]==false)
{
temp++;
DFS(i);
}
}
co<<temp;
return 0;
}