티스토리 뷰

https://www.acmicpc.net/problem/11724

 

11724번: 연결 요소의 개수

첫째 줄에 정점의 개수 N과 간선의 개수 M이 주어진다. (1 ≤ N ≤ 1,000, 0 ≤ M ≤ N×(N-1)/2) 둘째 줄부터 M개의 줄에 간선의 양 끝점 u와 v가 주어진다. (1 ≤ u, v ≤ N, u ≠ v) 같은 간선은 한 번만 주어진다.

www.acmicpc.net

#include<iostream>
#include<vector>
#include<stack>

using namespace std;

int N, M, result = 0;		//정점 개수, 간선 개수
vector<vector<int>> V;
vector<int> check;

void DFS(int node) {
	stack<int> S;

	S.push(node);
	check[node]++;

	while (!S.empty()) {
		int now = S.top();
		S.pop();

		for (int i = 0; i < V[now].size(); i++) {
			if (check[V[now][i]] == 0) {
				S.push(V[now][i]);
				check[V[now][i]]++;
			}
		}
	}
	result++;

}

int main(void) {
	cin >> N >> M;

	//vector 만들기
	for (int i = 0; i <= N; i++) {
		vector<int> temv;
		V.push_back(temv);

		check.push_back(0);
	}

	//입력
	for (int i = 0; i < M; i++) {
		int x, y;
		cin >> x >> y;
		V[x].push_back(y);
		V[y].push_back(x);
	}

	for (int i = 1; i <= N; i++) {
		if (check[i] == 0)
			DFS(i);
	}
	cout << result << endl;
}
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/07   »
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31
글 보관함