#문제
레벨: G4
알고리즘: dfs
풀이시간: 30분
힌트 참조 유무:
https://www.acmicpc.net/problem/1405
#문제 풀이
되게 간단한 문제이다. 문제에서는 배열에서 움직인다고 말을 안해서 눈치를 못챌 수도 있는데, 자기가 직접 30x30(넉넉한 배열)배열 중앙을 시작점으로 로봇을 움직이면 되는 문제이다. 갔던 길은 visited = true로 표시한채 말이다.
주의해야 할점은 정답은 10의 마이너스9승까지 나타낸다 했으니 float이 아닌 double로 출력해야 한다.
#풀이 코드
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
static int N;
static double[] dir; //동,서,남,북 순서대로
static double ans;
static boolean visited[][];
static int[] dx = {0, 0, 1, -1}; //동서남북 순서대로
static int[] dy = {1, -1, 0, 0};
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
N = Integer.parseInt(st.nextToken());
ans = 0;
dir = new double[4];
dir[0] = Double.parseDouble(st.nextToken()) / 100;
dir[1] = Double.parseDouble(st.nextToken()) / 100;
dir[2] = Double.parseDouble(st.nextToken()) / 100;
dir[3] = Double.parseDouble(st.nextToken()) / 100;
visited = new boolean[31][31];
visited[15][15] = true;
dfs(0, 1,15,15);
System.out.println(ans);
}
private static void dfs(int depth, double percent, int x, int y) {
if (depth == N) {
ans += percent;
return;
}
for (int i = 0; i < 4; i++) {
int nx = x + dx[i];
int ny = y + dy[i];
if (visited[nx][ny])
continue;
visited[nx][ny] = true;
dfs(depth + 1,percent * dir[i], nx, ny);
visited[nx][ny] = false;
}
}
}
'알고리즘 > DFS' 카테고리의 다른 글
[백준 1103] 게임 / 자바 / dfs + dp (0) | 2024.08.03 |
---|---|
[백준 16724] 피리 부는 사나이 / 자바 / dfs (0) | 2024.07.31 |
[백준 2250] 트리와 높이와 너비 / 자바 / dfs *** (0) | 2024.07.27 |
[백준 10159] 저울 / 자바 / dfs (0) | 2024.07.25 |
[백준 3548] 가장 가까운 공통 조상 / 자바 / dfs +LCA (0) | 2024.07.25 |