본문 바로가기
알고리즘/DFS

[백준 1405] 미친 로봇 / 자바 / dfs

by 순원이 2024. 7. 30.

#문제         

레벨: 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;
        }
    }
}