이 영역을 누르면 첫 페이지로 이동
시간의화살 블로그의 첫 페이지로 이동

시간의화살

페이지 맨 위로 올라가기

시간의화살

행복하세요

[백준] 1194 달이 차오른다, 가자 - Java

  • 2022.10.27 19:39
  • Algorithm/Baekjoon

 

 

 

외판원 순회 문제를 푼 적이 있다면 쉽게 풀 수 있는 문제이다.

 

주의할 점은 다음과 같다.

 

1. 열쇠를 먹은 후에는 돌아올 수 있어야 한다. visit배열을 3차원으로 설정하자.

2. 열쇠는 비트마스킹으로 처리해준다. 

3. 최단 거리를 구해야 하니 bfs를 사용해 순회하자.

 

비트마스킹과 visit배열을 3차원으로 설정하는 부분만 주의하면 다른 bfs 최단거리 문제와 같다.

 

 

 

import java.io.*;
import java.util.*;

public class Main {

    static int[] dr = {-1,1,0,0};
    static int[] dc = {0,0,-1,1};

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

        StringTokenizer st = new StringTokenizer(br.readLine());

        int N = Integer.parseInt(st.nextToken());
        int M = Integer.parseInt(st.nextToken());

        char[][] map = new char[N][M];

        Locate start = null;        

        for(int i=0; i<N; i++){
            String str = br.readLine();
            for(int j=0; j<M; j++){
                map[i][j] = str.charAt(j);
                if(map[i][j] == '0'){
                    start = new Locate(i, j, 0);
                }
            }
        }

        int[][][] visit = new int[N][M][1<<7];
        
        Queue<Locate> q = new LinkedList<>();
        visit[start.r][start.c][0] = 1;
        q.add(start);

        int min = 987654321;

        while(!q.isEmpty()){
            Locate cur = q.poll();      
            
            // System.out.println(cur.r + " " + cur.c + " " + cur.key);

            for(int i=0; i<4; i++){
                int nextR = cur.r + dr[i];
                int nextC = cur.c + dc[i];

                if(nextR >= N || nextR <= -1 || nextC >= M || nextC <= - 1) continue;
                if(visit[nextR][nextC][cur.key] != 0) continue;
                if(map[nextR][nextC] == '#') continue;
                
                if(map[nextR][nextC] == '1'){
                    visit[nextR][nextC][cur.key] = visit[cur.r][cur.c][cur.key] + 1;
                    min = Math.min(min, visit[nextR][nextC][cur.key]);                    
                    continue;
                }

                if(map[nextR][nextC] >= 'a' && map[nextR][nextC] <= 'f'){
                    int temp = map[nextR][nextC] - 'a';                    
                    int cmp = 1 << temp;

                    int nextKey = cur.key | cmp;

                    visit[nextR][nextC][nextKey] = visit[cur.r][cur.c][cur.key] + 1;
                    q.add(new Locate(nextR, nextC, nextKey));
                    continue;
                }

                if(map[nextR][nextC] >= 'A' && map[nextR][nextC] <= 'F'){
                    int temp = map[nextR][nextC] - 'A';
                    int cmp = 1 << temp;

                    int door = cur.key & cmp;

                    if(door != 0){
                        visit[nextR][nextC][cur.key] = visit[cur.r][cur.c][cur.key] + 1;
                        q.add(new Locate(nextR, nextC, cur.key));
                    }
                    continue;
                }

                visit[nextR][nextC][cur.key] = visit[cur.r][cur.c][cur.key] + 1; 
                q.add(new Locate(nextR, nextC, cur.key));
                

            }
        }

        System.out.println(min == 987654321 ? -1 : min-1);
        
        
        
    }
}

class Locate{
    int r, c;
    int key = 0;
    Locate(int r,int c){this.r=r;this.c=c;}
    Locate(int r, int c, int key){this.r=r;this.c=c;this.key=key;}
}
반응형
저작자표시 (새창열림)

'Algorithm > Baekjoon' 카테고리의 다른 글

[백준] 23743 방탈출 - Java  (1) 2022.11.02
[백준] 14950 정복자 - Java  (0) 2022.11.01
[백준] 1939 중량제한 - Java  (0) 2022.10.26
[백준] 3109 빵집 - Java  (0) 2022.10.25
[백준] 14590 KUBC League (Small) - C++  (0) 2022.10.06

댓글

이 글 공유하기

  • 구독하기

    구독하기

  • 카카오톡

    카카오톡

  • 라인

    라인

  • 트위터

    트위터

  • Facebook

    Facebook

  • 카카오스토리

    카카오스토리

  • 밴드

    밴드

  • 네이버 블로그

    네이버 블로그

  • Pocket

    Pocket

  • Evernote

    Evernote

다른 글

  • [백준] 23743 방탈출 - Java

    [백준] 23743 방탈출 - Java

    2022.11.02
  • [백준] 14950 정복자 - Java

    [백준] 14950 정복자 - Java

    2022.11.01
  • [백준] 1939 중량제한 - Java

    [백준] 1939 중량제한 - Java

    2022.10.26
  • [백준] 3109 빵집 - Java

    [백준] 3109 빵집 - Java

    2022.10.25
다른 글 더 둘러보기

정보

시간의화살 블로그의 첫 페이지로 이동

시간의화살

  • 시간의화살의 첫 페이지로 이동

검색

방문자

  • 전체 방문자
  • 오늘
  • 어제

카테고리

  • 분류 전체보기 (607)
    • Algorithm (205)
      • Data Structure (5)
      • Theory && Tip (33)
      • Baekjoon (166)
      • ALGOSPOT (1)
    • Spring (123)
      • Spring (28)
      • Spring Web MVC (20)
      • Spring Database (14)
      • Spring Boot (6)
      • Spring 3.1 (11)
      • Spring Batch (6)
      • Spring Security (16)
      • JPA (12)
      • Spring Data JPA (5)
      • QueryDSL (4)
      • eGovFramework (1)
    • Programming Language (74)
      • Java (19)
      • JavaScript (15)
      • C (25)
      • C++ (12)
      • Python (1)
      • PHP (2)
    • Computer Science (69)
      • Operating System (18)
      • Computer Network (17)
      • System Programming (22)
      • Universial Programming Lang.. (8)
      • Computer Architecture (4)
    • Database (21)
      • Database (7)
      • MySQL (3)
      • Oracle (3)
      • Redis (5)
      • Elasticsearch (3)
    • DevOps (20)
      • Docker && Kubernetes (8)
      • Jenkins (4)
      • Github Actions (0)
      • Amazon Web Service (8)
    • Machine Learning (28)
      • AI Introduction (28)
    • Mobile (28)
      • Android (21)
      • Flutter (7)
    • Solutions (14)
    • Life Logs (0)
    • 낙서장 (25)

최근 글

나의 외부 링크

메뉴

  • 홈

정보

13months의 시간의화살

시간의화살

13months

블로그 구독하기

  • 구독하기
  • RSS 피드

티스토리

  • 티스토리 홈
  • 이 블로그 관리하기
  • 글쓰기
Powered by Tistory / Kakao. Copyright © 13months.

티스토리툴바