[백준/Silver I] 쉬운 최단거리 - 14940

2024. 10. 16. 16:46·코딩 테스트 정복기/백준
반응형

[Silver I] 쉬운 최단거리 - 14940

문제 링크

성능 요약

메모리: 83384 KB, 시간: 592 ms

분류

너비 우선 탐색, 그래프 이론, 그래프 탐색

제출 일자

2024년 10월 16일 01:34:05

문제 설명

지도가 주어지면 모든 지점에 대해서 목표지점까지의 거리를 구하여라.

문제를 쉽게 만들기 위해 오직 가로와 세로로만 움직일 수 있다고 하자.

입력

지도의 크기 n과 m이 주어진다. n은 세로의 크기, m은 가로의 크기다.(2 ≤ n ≤ 1000, 2 ≤ m ≤ 1000)

다음 n개의 줄에 m개의 숫자가 주어진다. 0은 갈 수 없는 땅이고 1은 갈 수 있는 땅, 2는 목표지점이다. 입력에서 2는 단 한개이다.

출력

각 지점에서 목표지점까지의 거리를 출력한다. 원래 갈 수 없는 땅인 위치는 0을 출력하고, 원래 갈 수 있는 땅인 부분 중에서 도달할 수 없는 위치는 -1을 출력한다.

제출코드

//https://www.acmicpc.net/problem/14940
import java.io.*;
import java.util.*;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String[] temp = br.readLine().split(" ");
        int n = Integer.parseInt(temp[0]);
        int m = Integer.parseInt(temp[1]);
        int[][] map = new int[n][m];
        Queue<int[]> q = new LinkedList<>();
        for(int x=0;x<n;x++){
            temp = br.readLine().split(" ");
            for(int y=0;y<m;y++){
                map[x][y] = Integer.parseInt(temp[y]);
                if(map[x][y]==2){q.offer(new int[]{x,y,0});}
            }
        }

        // bfs
        int[] dx = {1,-1,0,0};
        int[] dy = {0,0,1,-1};
        int[] now;
        int x,y;

        while(!q.isEmpty()){
            now = q.poll();
            map[now[0]][now[1]] = now[2];
            for(int d=0;d<4;d++){
                x=now[0]+dx[d];
                y=now[1]+dy[d];
                if(x>=0 && x<n && y>=0 && y<m && map[x][y] == 1){
                    map[x][y] = now[2]-1;
                    q.add(new int[]{x,y,now[2]-1});
                }
            }

        }

        // answer
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++){
                bw.write(-1*map[i][j]+" ");
            }
            bw.write("\n");
        }
        bw.flush();
        bw.close();
        br.close();

    }
}
728x90
반응형

'코딩 테스트 정복기 > 백준' 카테고리의 다른 글

[백준/Silver IV] ATM - 11399  (1) 2024.10.18
[백준/Gold V] Z - 1074  (0) 2024.10.16
[백준/Silver II] 유기농 배추 - 1012  (0) 2024.10.16
[백준/Silver III] 1, 2, 3 더하기 - 9095  (0) 2024.10.16
[백준/Silver III] 피보나치 함수 - 1003  (0) 2024.10.16
'코딩 테스트 정복기/백준' 카테고리의 다른 글
  • [백준/Silver IV] ATM - 11399
  • [백준/Gold V] Z - 1074
  • [백준/Silver II] 유기농 배추 - 1012
  • [백준/Silver III] 1, 2, 3 더하기 - 9095
settong
settong
    250x250
  • settong
    개 발 자 국
    settong
  • 전체
    오늘
    어제
    • 전체보기 (202)
      • Computer Science (50)
        • Network (7)
        • Operating System (18)
        • Data Structure (9)
        • Database (11)
        • Algorithm (5)
      • Language (17)
        • Java (17)
        • Javascript (0)
        • Python (0)
      • Devops (20)
        • AWS (0)
        • Naver Cloud (16)
        • CICD (3)
        • 웹 서버 관리 (1)
      • Front (0)
        • React (0)
      • Backend (5)
        • Spring (5)
      • 코딩 테스트 정복기 (110)
        • 백준 (51)
        • 프로그래머스 (53)
        • 기타 (6)
      • etc (0)
      • 경제 상식 (0)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    lcs
    분할정복
    CI/CD
    github actions
    백준
    벨만포드
    프로그래머스
    BFS
    Network
    다이나믹프로그래밍
    ncp200
    백트래킹
    DFS
    완전탐색
    Spring Boot
    ncp
    해시
    ncp202
    다익스트라
    집합
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
settong
[백준/Silver I] 쉬운 최단거리 - 14940
상단으로

티스토리툴바