https://school.programmers.co.kr/learn/courses/30/lessons/43162
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
dfs로 아주 간단하게 풀 수 있는 문제다.
- 이차원 배열을 순회한다. 이때 아직 방문하지 않았으면서 값이 1이면 dfs를 시작한다.
- dfs를 통해 이어진 모든 노드들을 방문한다.
- dfs를 수행한 횟수가 네트워크 개수가 된다.
import java.util.*;
class Solution {
int answer = 0;
int n;
int[][] computers;
boolean[] visited;
public int solution(int n, int[][] computers) {
this.n = n;
this.computers = computers;
this.visited = new boolean[n];
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
if (computers[i][j] == 1 && !visited[i]) {
dfs(i);
answer++;
}
}
}
return answer;
}
public void dfs(int start) {
visited[start] = true;
for (int i = 0; i < n; i++) {
if (computers[start][i] == 1 && !visited[i]) {
dfs(i);
}
}
}
}
'CS > Algorism' 카테고리의 다른 글
[2024 KAKAO WINTER INTERNSHIP] 산 모양 타일링 (1) | 2024.06.04 |
---|---|
99클럽 코테 스터디 16일차 TIL: [프로그래머스] 섬 연결하기 (0) | 2024.06.04 |
99클럽 코테 스터디 14일차 TIL: [프로그래머스] 단어 변환 (0) | 2024.06.02 |
99클럽 코테 스터디 13일차 TIL: [프로그래머스] 아이템 줍기 (1) | 2024.06.01 |
99클럽 코테 스터디 12일차 TIL: [프로그래머스] 여행경로 (0) | 2024.05.31 |