728x90
숨바꼭질
문제
수빈이는 동생과 숨바꼭질을 하고 있다. 수빈이는 현재 점 N(0 ≤ N ≤ 100,000)에 있고, 동생은 점 K(0 ≤ K ≤ 100,000)에 있다. 수빈이는 걷거나 순간이동을 할 수 있다. 만약, 수빈이의 위치가 X일 때 걷는다면 1초 후에 X-1 또는 X+1로 이동하게 된다. 순간이동을 하는 경우에는 1초 후에 2*X의 위치로 이동하게 된다.
수빈이와 동생의 위치가 주어졌을 때, 수빈이가 동생을 찾을 수 있는 가장 빠른 시간이 몇 초 후인지 구하는 프로그램을 작성하시오.
입력
첫 번째 줄에 수빈이가 있는 위치 N과 동생이 있는 위치 K가 주어진다. N과 K는 정수이다.
출력
수빈이가 동생을 찾는 가장 빠른 시간을 출력한다.
예제 입력 1
5 17
예제 출력 1
4
풀이
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
import java.util.stream.IntStream;
@BOJ( number = 1697,
tier = BaekjoonTier.SILVER_I,
solveDate = @SolveDate(year = 2022, month = 2, day = 9))
public class 백준1697 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int[] inputs = Arrays.stream(br.readLine().split(" ")).mapToInt(Integer::parseInt).toArray();
int tagger = inputs[0];
int hider = inputs[1];
HideMap hideMap = new HideMap();
System.out.println(hideMap.play(tagger, hider));
}
public static class HideMap {
private ArrayList<Integer> map = new ArrayList<>();
private ArrayList<Boolean> isVisited = new ArrayList<>();
public HideMap(){
IntStream.rangeClosed(0,100000).forEach(i -> {
map.add(0);
isVisited.add(Boolean.FALSE);
});
}
public int play(int tagger, int hider){
if(tagger == hider) return 0;
isVisited.set(tagger, Boolean.TRUE);
Deque<Integer> deque = new ArrayDeque<>();
deque.add(tagger);
isVisited.set(tagger, Boolean.TRUE);
while (!deque.isEmpty()){
Integer current = deque.poll();
if(current == hider) return map.get(current);
checkAndEnque(deque, current,current+1);
checkAndEnque(deque, current,current-1);
checkAndEnque(deque, current,current * 2);
}
return -1;
}
private void checkAndEnque(Deque<Integer> deque, Integer isAs,Integer toBe) {
if(toBe > -1 && toBe <= 100000 && !isVisited.get(toBe)) {
map.set(toBe, map.get(isAs) + 1);
isVisited.set(toBe, Boolean.TRUE);
deque.offer(toBe);
}
}
}
}
728x90
'Algorithm > 백준' 카테고리의 다른 글
[백준/2206/Java] 벽 부수고 이동하기 (0) | 2022.02.12 |
---|---|
[백준/7562/Java] 나이트의 이동 (0) | 2022.02.10 |
[백준/7569/Java] 토마토 (0) | 2022.02.09 |
[백준/2178/Java] 미로 탐색 (0) | 2022.02.07 |
[백준/7576/Java] 토마토 (0) | 2022.02.07 |