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
- 자바
- 레디스
- F-Lab
- 도커
- 로드밸런서
- grafana
- 알고리즘
- 데이터구조
- 백엔드
- MySQL
- redis
- error
- 플러터
- 후기
- 자바백엔드
- github
- nGrinder
- AWS
- Spring
- 멘토링
- 성능테스트
- 부트캠프
- EC2
- FLAB
- backend
- 코딩테스트
- 트러블슈팅
- Flutter
- 에프랩
- java
Archives
- Today
- Total
민스씨의 일취일장
Java | 백준 26169 세 번 이내에 사과를 먹자 문제풀이 및 분석 본문
반응형
백준 26169 세 번 이내에 사과를 먹자 문제에 대한 글입니다.
백준 26169 세 번 이내에 사과를 먹자
문제
문제 정보는 아래 링크에서 확인할 수 있다.
풀이
재귀 호출을 이용한 DFS
재귀호출을 이용해서 깊이 우선 탐색을 진행했다.
- 특징
3의 깊이까지만 탐색을 진행한다. 이를 위해서 깊이 정보를 파악하기 위한 변수 하나를 정의해 주어야 한다.
int depth = 0;
- 경계값 주의
처음 시작하는 지점은 사과의 개수를 파악하지도(직접 제출해 보았다) 않았고 깊이에서도 계산하지 않는다.
전체 코드
public class baekjoon26169 {
static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
static StringTokenizer st;
static int[][] map = new int[5][5];
static int x, y, numOfApple;
static int[][] var = {{1,0}, {0,1}, {-1,0}, {0,-1}};
static void input() throws IOException{
for(int i=0; i<5; i++){
st = new StringTokenizer(br.readLine());
for(int j=0; j<5; j++){
map[i][j] = Integer.parseInt(st.nextToken());
}
}
st = new StringTokenizer(br.readLine());
x = Integer.parseInt(st.nextToken());
y = Integer.parseInt(st.nextToken());
}
static boolean execute(){
boolean[][] visited = new boolean[5][5];
int depth = 0;
visited[x][y] = true;
if(map[x][y] == -1) return false;
dfs(x, y, depth, visited);
if(numOfApple>=2){
return true;
} else {
return false;
}
}
static void dfs(int x, int y, int depth, boolean[][] visited){
if(numOfApple>=2 || depth == 3) return;
for(int i=0 ; i<4; i++){
int newX = x + var[i][0];
int newY = y + var[i][1];
if(newX <0 || newY <0 || newX >=5 || newY >=5) continue;
if(visited[newX][newY]) continue;
if(map[newX][newY] == -1) continue;
depth++;
visited[newX][newY] = true;
if(map[newX][newY]==1) numOfApple++;
dfs(newX, newY, depth, visited);
if(numOfApple<2) {
visited[newX][newY] = false;
depth--;
numOfApple -= map[newX][newY] == 1 ? 1 : 0;
}
}
}
public static void main(String[] args) throws IOException{
input();
if(execute()){
System.out.println(1);
} else {
System.out.println(0);
}
}
}
728x90
반응형
'Data Structure & Algorithm > Java' 카테고리의 다른 글
Java | 백준 11057 오르막 수 (0) | 2024.02.09 |
---|---|
Java | 백준 11724 연결 요소의 개수 (0) | 2024.02.08 |
Java | 백준 1388 바닥 장식 문제풀이 및 분석 (0) | 2024.02.07 |
Java | 백준 13300 방배정 풀이 전략 기록 (0) | 2023.08.09 |
Java | 백준 11328 Strfry 풀이 전략 기록 (0) | 2023.08.09 |