반응형
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 | 29 | 30 | 31 |
Tags
- 상한가 분석
- 경제뉴스 요약
- 코딩테스트
- 프로그래머스
- java
- boj
- 손경제 요약
- 상한가
- 백준
- 경제
- 손경제
- 자바
- 주식 상한가
- 급등주
- 이진우
- 주식
- Programmers
- 급등 이유
- 주식 분석
- 손에 잡히는 경제 요약
- 손에 잡히는 경제
- 경제뉴스
- 파이썬
- 이진우의 손에 잡히는 경제
- 코테
- 알고리즘
- 상한가 이유
- 급등주 분석
- Python
- 테마주
Archives
- Today
- Total
Completion over Perfection
백준 2606 - 바이러스 (JAVA 자바) 본문
반응형
백준 2606 - 바이러스 (JAVA 자바)
DFS의 가장 기본이 되는 문제 같습니다.
풀이방법은 아래의 사항들을 참고하여 풀어주시면 됩니다.
1. 시작지점은 무조건 1번 컴퓨터에서부터 시작되므로,
1번에서 연결된 컴퓨터들만 모두 돌면서 wasted 변수를 증가시켜준다.
2. 한번 방문한 지점은 방문체크를 해주고, 다시 방문 안하도록 해준다.
3. 간선으로 연결되어 있는 곳은 DFS를 돌려주고,
DFS를 돌기 전에 (감염된 컴퓨터의 갯수를 세야 하므로)
wasted 함수를 1 증가 시켜준다.
4. 마지막에 wasted변수를 출력해주면 정답이 된다.
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
import java.util.*;
public class Baekjoon_virus {
static int computers,networks,wasted;
static boolean visits[];
static boolean map[][];
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
computers = sc.nextInt();
networks = sc.nextInt();
visits = new boolean [computers+1];
map = new boolean [computers+1][computers+1];
wasted = 0;
for (int i=1; i<=networks; i++) {
int tmp1 = sc.nextInt();
int tmp2 = sc.nextInt();
map[tmp1][tmp2] = true;
map[tmp2][tmp1] = true;
}
dfs(1);
System.out.println(wasted);
}
private static void dfs(int start) {
visits[start] = true;
for(int i=1; i<=computers; i++) {
if(map[start][i] && !visits[i]) {
wasted++;
dfs(i);
}
}
}
}
|
cs |
반응형
'앨고리듬 알고리즘' 카테고리의 다른 글
백준 4963 - 섬의 개수 (JAVA 자바) (0) | 2020.11.25 |
---|---|
백준 11724 - 연결 요소의 개수 (JAVA 자바) (0) | 2020.11.24 |
백준 2667 - 단지번호붙이기 (JAVA 자바) (0) | 2020.11.17 |
백준 2798 - 블랙잭 (JAVA 자바) (0) | 2020.11.17 |
백준 9019 - DSLR (JAVA, 자바) (0) | 2020.11.14 |
Comments