Pagini recente » Cod sursa (job #2624081) | Cod sursa (job #253659) | Cod sursa (job #1881751) | Cod sursa (job #2827762) | Cod sursa (job #1704139)
#include <fstream>
#include <vector>
#define InFile "dfs.in"
#define OutFile "dfs.out"
#define MAX 100001
using namespace std;
void DFS (unsigned int node);
unsigned int N, M;
unsigned int X, Y;
vector < unsigned int > G[MAX];
bool used[MAX];
unsigned int i;
unsigned int solution;
int main ()
{
ifstream fin (InFile);
fin >> N >> M;
for (i=1; i<=M; i++)
{
fin >> X >> Y;
G[X].push_back(Y);
G[Y].push_back(X);
}
fin.close();
for (i=1; i<=N; i++)
if (!used[i])
{
DFS(i);
solution++;
}
ofstream fout (OutFile);
fout << solution;
fout.close();
return 0;
}
void DFS (unsigned int node)
{
vector < unsigned int > :: iterator j;
used[node] = 1;
for (j=G[node].begin(); j!=G[node].end(); j++)
if (!used[*j])
DFS(*j);
}