Study/Algorithm

03. CLOCKSYNC

jhin.lee 2019. 3. 3. 16:40

알고리즘문제해결전략 p168



문제


시계 맞추기 (문제ID:CLOCKSYNC, 난이도 중)

알고스팟 링크



풀이


이 문제는 완전탐색의 탈을 쓴 연립방정식 문제이다.

전체 경우의 수가 4^10이므로 완전탐색을 하라고 책에서는 말하지만

많은 사람들이 손으로 연립방정식을 풀고 그냥 옮겨 적어서 풀었다.

나도 상호 종속적인 몇 개의 버튼을 적당히 거르고 적당히 코드로도 검증을 해서 풀었다.


완전탐색으로 구현하고 싶다면 한 스위치를 4번 누르는것은 0번 누르는 것과 같다는 것만 명심하면 된다.

그래서 나온 경우의 수가 4^10으로 그냥 모든 버튼의 모든 경우의 수를 적당히 구하면 된다.

약 100만개 정도라서 아마 시간이 오래 걸릴 것 같지는 않다.


코드


이 코드는 AC를 받은 코드지만 별로 참고하기는 좋은 코드가 아닌 것 같다.

딱히 수학적으로 푼것도 아니고 완전탐색도 아닌 어중간한 코드여서.. (하지만 절대 2번 풀고 싶지는 않은 문제라...)

이 링크 에서 가장 빠른 답안과 가장 짧은 답안등을 보면서 다른 좋은 코드를 참고 하기를 바란다.