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
- LEVEL2
- Brute-force
- TDD
- backtracking
- 코틀린
- 백트래킹
- lambda
- java
- 백준
- 그래프
- BFS
- baekjoon
- 프로젝트
- 운영체제
- DP
- 스프링
- OS
- 자료구조
- 자바
- back-end
- Spring
- DFS
- programmers
- 프로그래머스
- 모던자바
- algorithm
- Java8
- 네트워크
- kotlin
- 알고리즘
Archives
- Today
- Total
요깨비's LAB
[프로그래머스, Java] 거리두기 확인하기 본문
import java.util.*;
class Solution {
public int[] solution(String[][] places) {
int[] answer = new int[5];
int caseLen = places.length;
for (int i = 0; i < 5; i++) {
char[][] map = new char[5][5];
List<Participant> participants = new ArrayList<>();
for (int j = 0; j < 5; j++) {
char[] carr = places[i][j].toCharArray();
for (int k = 0; k < 5; k++) {
if (carr[k] == 'P') {
participants.add(new Participant(j, k));
}
map[j][k] = carr[k];
}
}
answer[i] = validate(participants, map);
}
return answer;
}
public int validate(List<Participant> participants, char[][] map) {
for (Participant participant : participants) {
Queue<Element> queue = new LinkedList<>();
boolean[][] isVisited = new boolean[5][5];
Element element = new Element(participant.row, participant.col);
isVisited[element.row][element.col] = true;
queue.add(element);
while (!queue.isEmpty()) {
Element polledElement = queue.poll();
if (map[polledElement.row][polledElement.col] == 'P' && polledElement.count > 0 && polledElement.count <= 2) {
return 0;
}
if (polledElement.row - 1 >= 0
&& (map[polledElement.row - 1][polledElement.col] == 'O' || map[polledElement.row - 1][polledElement.col] == 'P')
&& !isVisited[polledElement.row - 1][polledElement.col]) {
isVisited[polledElement.row - 1][polledElement.col] = true;
queue.add(new Element(polledElement.row - 1, polledElement.col, polledElement.count + 1));
}
if (polledElement.row + 1 < 5
&& (map[polledElement.row + 1][polledElement.col] == 'O' || map[polledElement.row + 1][polledElement.col] == 'P')
&& !isVisited[polledElement.row + 1][polledElement.col]) {
isVisited[polledElement.row + 1][polledElement.col] = true;
queue.add(new Element(polledElement.row + 1, polledElement.col, polledElement.count + 1));
}
if (polledElement.col - 1 >= 0
&& (map[polledElement.row][polledElement.col - 1] == 'O' || map[polledElement.row][polledElement.col - 1] == 'P')
&& !isVisited[polledElement.row][polledElement.col - 1]) {
isVisited[polledElement.row][polledElement.col - 1] = true;
queue.add(new Element(polledElement.row, polledElement.col - 1, polledElement.count + 1));
}
if (polledElement.col + 1 < 5
&& (map[polledElement.row][polledElement.col + 1] == 'O' || map[polledElement.row][polledElement.col + 1] == 'P')
&& !isVisited[polledElement.row][polledElement.col + 1]) {
isVisited[polledElement.row][polledElement.col + 1] = true;
queue.add(new Element(polledElement.row, polledElement.col + 1, polledElement.count + 1));
}
}
}
return 1;
}
class Participant {
int row, col;
public Participant(int row, int col) {
this.row = row;
this.col = col;
}
}
class Element {
int row, col;
int count = 0;
public Element(int row, int col) {
this.row = row;
this.col = col;
}
public Element(int row, int col, int count) {
this.row = row;
this.col = col;
this.count = count;
}
}
}
'알고리즘(Java) > 프로그래머스' 카테고리의 다른 글
[프로그래머스, Java] 수식 최대화 (0) | 2021.10.15 |
---|---|
[프로그래머스, Java] 자물쇠와 열쇠 (0) | 2021.09.23 |
[프로그래머스, Java] 메뉴 리뉴얼 (0) | 2021.08.17 |
[프로그래머스, JAVA] 행렬 테두리 회전하기 (0) | 2021.06.15 |
[프로그래머스, JAVA] 뉴스 클러스터링 (0) | 2021.06.14 |
Comments