반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- qsort
- template
- Critical_Path_Analysis
- red-black tree
- 구현
- 13305
- 백준
- '0'
- connected_component
- 5397
- 문법
- sstream
- 알고리즘
- class_template
- singly Linked List
- data_structure
- 예제
- Biconnected_Component
- Articulation_Point
- sort
- 총정리
- deletion
- STL
- list
- Pair
- Heap
- Algorithm
- 자료구조
- c++
- function_template
Archives
- Today
- Total
- Today
- Total
- 방명록
어제의 나보다 성장한 오늘의 나
[C++][BFS / DFS] 백준 2606번 문제 풀이 본문
반응형
간단한
BFS or DFS 문제
◎ Data structure는 Deque를 사용함
◎ adj_list 먼저 만들고 DFS Search로 답을 구함 (BFS 사용해도 됨)
◎ adj_list , check를 전역 변수로 선언 하지 않고 매개변수로 보내줌 ( 동적 할당을 위해 )
Code
// BaekJoon 2606
// Title : Virus
// URL : https://www.acmicpc.net/problem/2606
#include <iostream>
#include <deque>
using namespace std;
void DFS(deque<int> adj_list[] ,deque<bool> &check , int i , int &cnt){
check[i-1] = true;
for(int j = 0 ; j < adj_list[i-1].size() ; ++j){
if(check[adj_list[i-1][j] - 1] == false){ DFS(adj_list,check , adj_list[i-1][j], cnt) ; cnt++; }
}
}
int main(int argc , char** argv){
int cmpr , num , first , second;
int cnt = 0;
cin >> cmpr >> num;
deque<int> adj_list[cmpr];
deque<bool> check(cmpr , false);
// Making adj_list
while(num--){
cin >> first >> second;
adj_list[first - 1].push_back(second);
adj_list[second - 1].push_back(first);
}
// DFS search
DFS(adj_list , check , 1 , cnt);
cout << cnt;
}
https://www.acmicpc.net/problem/2606
2606번: 바이러스
첫째 줄에는 컴퓨터의 수가 주어진다. 컴퓨터의 수는 100 이하이고 각 컴퓨터에는 1번 부터 차례대로 번호가 매겨진다. 둘째 줄에는 네트워크 상에서 직접 연결되어 있는 컴퓨터 쌍의 수가 주어
www.acmicpc.net
반응형
'c++ > 백준 문제 풀이' 카테고리의 다른 글
[C++] [BFS / DFS] 백준 2331 번 문제 풀이 (0) | 2022.08.19 |
---|---|
[C++][BFS / DFS] 백준 10451번 문제 풀이 (0) | 2022.08.18 |
[C++][자료구조 Stack] 백준 10828번 문제 풀이 (0) | 2022.07.24 |
[C++] 백준 5397번 풀이 (0) | 2022.07.24 |
[C++][집합 / 자료구조] 백준 1717번 풀이 및 설명 (0) | 2022.07.01 |
Comments