본문 바로가기
이론/코딩테스트

[백준] 11724번 연결 요소의 개수 (DFS)

by 퇴근후개발 2022. 7. 28.
반응형

-문제

-코드

#include<stdio.h>
#include<vector>
using namespace std;

int n, m, cnt, ch[1002];
vector<int> vertex[1002];
void DFS(int v)
{
	for (int i = 0; i < vertex[v].size(); i++)
	{
		if (ch[vertex[v][i]] == 0)
		{
			ch[vertex[v][i]] = 1;
			DFS(vertex[v][i]);
		}
	}
}
int main()
{
	int a,b;
	scanf("%d %d", &n, &m);

	for (int i = 0; i < m; i++)
	{
		scanf("%d %d", &a, &b);
		vertex[a].push_back(b);
		vertex[b].push_back(a);
	}

	for(int i=1; i<=n; i++)
	{ 
		if (ch[i] == 0)
		{
			ch[i] = 1;
			DFS(i);
			cnt++;
		}
	}
	printf("%d", cnt);
	return 0;
}
반응형