Pagini recente » Cod sursa (job #441022) | Cod sursa (job #766470)
Cod sursa(job #766470)
#include<iostream>
#include<fstream>
#include<vector>
#include<algorithm>
#include<stack>
#include<bitset>
using namespace std;
int n,m,x,y,conex;
vector <int > a[100001];
bool apar[100001];
void DFS(int nod)
{
//stack <int> s;
//s.push(nod);
apar[nod]=1;
int i;
for(i=0;i<a[nod].size();++i)
{
if (!apar[a[nod][i]])
DFS(a[nod][i]);
}
}
int main(void)
{
fstream f,g;
f.open("dfs.in",ios::in);
g.open("dfs.out",ios::out);
f>>n>>m;
int i;
for (i=1;i<=m;i++)
{
f>>x>>y;
a[x].push_back(y);
a[y].push_back(x);
}
DFS(1);
conex++;
int ok=0;
while (ok==0)
{
ok=1;
for (i=1;i<=n;++i)
if (apar[i]==0)
{
DFS(i);
ok=0;
conex++;
}
}
g<<conex;
}