베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • 스프링
    • BFS
    • 스레드
    • 운영체제
    • 이펙티브자바
    • java
    • 자바8
    • Spring
    • 토비스프링
    • 데이터베이스
    • 스프링시큐리티
    • 백준
    • 알고리즘
    • jpa
    • dfs
    • 함수형인터페이스
    • 자바
    • C++
    • leetcode
    • 코드업

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    알고리즘/Baekjoon

    [백준] 1697 숨바꼭질 (JAVA)

    2022. 4. 6. 11:48

    ✉️문제

    https://www.acmicpc.net/problem/1697

     

    1697번: 숨바꼭질

    수빈이는 동생과 숨바꼭질을 하고 있다. 수빈이는 현재 점 N(0 ≤ N ≤ 100,000)에 있고, 동생은 점 K(0 ≤ K ≤ 100,000)에 있다. 수빈이는 걷거나 순간이동을 할 수 있다. 만약, 수빈이의 위치가 X일

    www.acmicpc.net

     

    📝 접근

       최단거리를 구하는 문제이다. DFS로 풀 수 있을 것 같지만, DFS로 구현하면 커팅 기법을 사용해도 지수 시간 복잡도를 가지기 때문에 시간 내에 통과하기 어렵다. 따라서 BFS를 이용해야 한다.

     

    🗝 문제풀이

    package baekjoon;
    
    import java.util.LinkedList;
    import java.util.Queue;
    import java.util.Scanner;
    
    public class B1697 {
    
        static int[] ch = new int[100001];
    
        public static void main(String[] args) {
            Scanner sc = new Scanner(System.in);
    
            int n = sc.nextInt(); // 수빈 위치
            int k = sc.nextInt(); // 동생 위치
    
            BFS(n,k);
            System.out.println(ch[k] - 1); // 방문 표시를 위해 1부터 시작했기 때문에 -1을 해준다.
        }
    
        public static void BFS(int n, int k) {
            Queue<Integer> q = new LinkedList<>();
            q.add(n);
            ch[n] = 1; // 현재 수빈의 위치에 방문 표시를 한다.
    
            while(!q.isEmpty()) {
                int now = q.poll();
    
                if(now == k) return;
    
                int backward = now - 1;
                int forward = now + 1;
                int tele = now * 2;
    
                // 만약 backward, forward, tele의 값 들을 방문하지 않았다면
                // 방문표시를 하고 queue에 집어 넣는다. 
                if(backward >= 0 && ch[backward] == 0) {
                    ch[backward] = ch[now] + 1;
                    q.add(backward);
                }
    
                if(forward <= 100000 && ch[forward] == 0) {
                    ch[forward] = ch[now] + 1;
                    q.add(forward);
                }
    
                if(tele <= 100000 && ch[tele] == 0) {
                    ch[tele] = ch[now] + 1;
                    q.add(tele);
                }
            }
        }
    }

     

     

      '알고리즘/Baekjoon' 카테고리의 다른 글
      • [백준] 2468 안전 영역 (JAVA)
      • [백준] 5014 스타트링크 (JAVA)
      • [백준] 7569 토마토 (JAVA)
      • [백준] 7576 토마토 (JAVA)
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바