1. 좌, 우로만 이동 가능
2. K = 0 인 경우가 있어서 split 할 때 에러가 난다. (try catch 로 해결)
3. 모든 경우를 다 확인한다고 했을 때, O(N)
import java.util.*; | |
import java.io.*; | |
/** | |
* https://www.acmicpc.net/problem/13700 | |
* BOJ 백준온라인져지 13700 완전 범죄 풀이 | |
*/ | |
public class Main { | |
private static BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); | |
public static void main(String args[]) throws IOException { | |
BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); | |
// N, S, D, F, B, K | |
String str1[] = br.readLine().split(" "); | |
int N = Integer.parseInt(str1[0]); | |
int S = Integer.parseInt(str1[1]) - 1; | |
int D = Integer.parseInt(str1[2]) - 1; | |
int F = Integer.parseInt(str1[3]); | |
int B = Integer.parseInt(str1[4]); | |
int K = Integer.parseInt(str1[5]); | |
int map[] = new int[N]; | |
try { | |
String str2[] = br.readLine().split(" "); | |
for (int i = 0; i < K; i++) map[Integer.parseInt(str2[i]) - 1] = 1; | |
} catch (Exception e) {} | |
Queue<Integer> q = new LinkedList<>(); | |
int step[] = new int[N]; | |
for (int i = 0; i < N; i++) step[i] = -1; | |
step[S] = 0; | |
q.offer(S); | |
while (!q.isEmpty()) { | |
int x = q.poll(); | |
int l = x - B; | |
int r = x + F; | |
if (x == D) { | |
System.out.println(step[x]); | |
return; | |
} | |
if (l >= 0 && map[l] == 0 && step[l] == -1) { | |
step[l] = step[x] + 1; | |
q.offer(l); | |
} | |
if (r < N && map[r] == 0 && step[r] == -1) { | |
step[r] = step[x] + 1; | |
q.offer(r); | |
} | |
} | |
bw.write("BUG FOUND"); | |
bw.flush(); | |
} | |
} |
문제
홍익대학교 근처에 있는 오락실에 새로운 게임이 들어왔다. 이 게임을 클리어하려면 방금 막 금은방을 턴 마포구 대도 X가 되어 아무에게도 들키지 않고 X의 집에 무사히 도착해야 한다. 게임은 오직 좌우 버튼 두 개로만 진행되고 규칙은 아래와 같다.
- 마포구의 모든 건물은 일렬로 나열되어 있고 각 건물에는 1번부터 N번까지 번호가 지정되어 있다. 마포구에는 K개의 경찰서가 있고 경찰 내부에는 이미 X의 얼굴이 알려졌다.
- 게임이 시작될 때 X는 막 범행을 끝내고 금은방 S에 있다.
- X는 자신의 집 D에 마포구를 떠날 수 있는 비밀 통로를 만들어놓았다. 따라서 경찰에게 발각되지 않고 무사히 집으로 돌아가야 한다.
- 좌(←) 버튼을 누르면 후방으로, 우(→) 버튼을 누르면 전방으로 이동한다. X는 마포구 내에서만 이동할 수 있으며, 자신이 오랜 연구 끝에 알아낸 이동 방식을 맹신하여 오직 그 방식으로만 이동한다.
- X의 달리기는 매우 빨라서 전방으로 F개의 건물, 후방으로 B개의 건물을 얼굴이 보이지 않는 빠르기로 달릴 수 있다. 하지만 자신도 주체할 수 없을 만큼 빨라서 중간에 멈출 수 없으며, 한 번 달리면 너무 힘들어 10초 동안 건물 앞에서 휴식을 취해야 한다.
- X가 경찰서 앞에서 휴식을 취할 경우 그는 집에 돌아가지 못하고 체포된다.
이 게임은 아직 베타 버전이라 무사히 집으로 가는 방법이 없는 버그도 존재한다.
지언이의 취미는 오락실 게임을 누구보다 빠르게 클리어하는 것이다. 그래서 대도 X가 무사히 집에 도착할 수 있는 여러 방법 중에서도 좌우 버튼을 가장 최소로 눌렀을 때의 횟수를 알고 싶다.
마포구 건물의 개수 N, 털린 금은방 S, 빈집털이범의 집 D, 앞으로 한 번에 달릴 수 있는 건물 수 F, 뒤로 한 번에 달릴 수 있는 건물 수 B, 마포구 경찰서의 개수 K, 각 경찰서의 건물 번호 l1, l2, …, lK가 주어질 때 대도 X가 무사히 집에 도착하기 위해 버튼을 눌러야 하는 최소 횟수를 출력하는 프로그램을 작성해라.
만약 집으로 가는 방법이 없는 경우를 발견했다면 이 데이터를 게임 회사에 알리기 위해 “BUG FOUND”를 출력한다.
입력
첫째 줄에 N, S, D, F, B, K가 주어지고, K > 0인 경우에는 둘째 줄에 경찰서의 위치 l1, l2, …, lK가 주어진다. (1 ≤ S, D, k ≤ N ≤ 100000, 0 ≤ F, B ≤ 100000, 0 ≤ K ≤ N/2, S ≠ D ≠ l)
출력
첫째 줄에 대도 X가 건물 S에서 자신의 집 D로 무사히 가기 위해 지언이가 버튼을 눌러야 하는 최소 횟수를 출력한다. 만약, D에 도달할 수 없는 데이터인 경우 “BUG FOUND”를 출력한다.
예제 입력 1
20 1 20 2 1 4 5 10 15 19
예제 출력 1
14
예제 입력 2
20 1 20 2 1 3 5 6 9
예제 출력 2
BUG FOUND
출처
University > 홍익대학교 > 홍익대학교 프로그래밍 경진대회 2016 C번
'IT > 알고리즘' 카테고리의 다른 글
BOJ 백준온라인져지 11728 배열 합치기 풀이 (1) | 2018.05.25 |
---|---|
BOJ 백준온라인져지 13698 Hawk eyes 풀이 (0) | 2018.05.24 |
BOJ 백준온라인져지 13701 중복 제거 풀이 (0) | 2018.05.24 |
BOJ 백준온라인져지 11722 가장 긴 감소하는 부분 수열 풀이 (0) | 2018.05.23 |
BOJ 백준온라인져지 12738 가장 긴 증가하는 부분 수열 3 풀이 (0) | 2018.05.23 |