Pagini recente » Cod sursa (job #538767) | Cod sursa (job #899933) | Cod sursa (job #2301700) | Cod sursa (job #696348) | Cod sursa (job #1198036)
/*
* Includes
*/
#include <fstream>
#include <vector>
using namespace std;
ifstream fin("dfs.in");
ofstream fout("dfs.out");
/*
* Limits
*/
#define NLIM 100000
/*
* Variables
*/
int N, M, answer;
vector < int > V[NLIM];
bool beenThere[NLIM];
/*
* Here we go
*/
void read()
{
int x, y;
fin >> N >> M;
for(int i = 1; i <= M; i++)
{
fin >> x >> y;
V[x].push_back(y);
V[y].push_back(x);
}
}
void DFS(int node)
{
beenThere[node] = true;
for(unsigned int i = 0; i < V[node].size(); i++)
{
if(!beenThere[V[node][i]])
DFS(V[node][i]);
}
}
void solve()
{
for(int i = 1; i <= N; i++)
{
if(!beenThere[i])
{
answer += 1;
DFS(i);
}
}
}
int main()
{
read();
solve();
fout << answer;
return 0;
}