이번에 해결해 볼 문제는 프로그래머스에 있는 자물쇠와 열쇠이다.
문제 설명
- 크기 n x n의 자물쇠와 크기 m x m의 열쇠가 있다.(m <= n)
- 자물쇠와 열쇠 모두 돌기는 1로 돌기가 아닌 홈은 0으로 표현되어 있다.
- 열쇠를 상하좌우 이동 또는 회전을 통해 자물쇠에 꽂을 수 있다면 True 그렇지 않다면 False를 return 할 수 있다.
문제 예시
문제 해결 아이디어
위의 문제를 이해하면 다음을 떠올릴 수 있다.
문제 해결 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
def rotation(arr, m):
rotation_arr = [[0] * m for _ in range(m)]
for i in range(m):
for j in range(m):
rotation_arr[j][m-i-1] = arr[i][j]
return rotation_arr
def check(lock, n):
for i in range(n, 2*n):
for j in range(n, 2*n):
if lock[i][j] != 1:
return False
return True
def connect(key, m, lock, row, col, reverse = False):
if reverse:
for i in range(m):
for j in range(m):
lock[row + i][col + j] -= key[i][j]
return lock
else:
for i in range(m):
for j in range(m):
lock[row + i][col + j] += key[i][j]
return lock
def solution(key, lock):
n = len(lock)
m = len(key)
new_lock = [[0] * (3*n) for _ in range(3*n)]
for i in range(n):
for j in range(n):
new_lock[i+n][j+n] = lock[i][j]
for _ in range(4):
key = rotation(key, m)
for i in range(2*n):
for j in range(2*n):
new_lock = connect(key, m, new_lock, i, j)
if check(new_lock, n):
return True
new_lock = connect(key, m, new_lock, i, j, True)
return False