forked from ndb796/python-for-coding-test
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path4.py
46 lines (43 loc) ยท 1.68 KB
/
4.py
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
44
45
46
# 2์ฐจ์ ๋ฆฌ์คํธ 90๋ ํ์ ํ๊ธฐ
def rotate_a_matrix_by_90_degree(a):
n = len(a) # ํ ๊ธธ์ด ๊ณ์ฐ
m = len(a[0]) # ์ด ๊ธธ์ด ๊ณ์ฐ
result = [[0] * n for _ in range(m)] # ๊ฒฐ๊ณผ ๋ฆฌ์คํธ
for i in range(n):
for j in range(m):
result[j][n - i - 1] = a[i][j]
return result
# ์๋ฌผ์ ์ ์ค๊ฐ ๋ถ๋ถ์ด ๋ชจ๋ 1์ธ์ง ํ์ธ
def check(new_lock):
lock_length = len(new_lock) // 3
for i in range(lock_length, lock_length * 2):
for j in range(lock_length, lock_length * 2):
if new_lock[i][j] != 1:
return False
return True
def solution(key, lock):
n = len(lock)
m = len(key)
# ์๋ฌผ์ ์ ํฌ๊ธฐ๋ฅผ ๊ธฐ์กด์ 3๋ฐฐ๋ก ๋ณํ
new_lock = [[0] * (n * 3) for _ in range(n * 3)]
# ์๋ก์ด ์๋ฌผ์ ์ ์ค์ ๋ถ๋ถ์ ๊ธฐ์กด์ ์๋ฌผ์ ๋ฃ๊ธฐ
for i in range(n):
for j in range(n):
new_lock[i + n][j + n] = lock[i][j]
# 4๊ฐ์ง ๋ฐฉํฅ์ ๋ํด์ ํ์ธ
for rotation in range(4):
key = rotate_a_matrix_by_90_degree(key) # ์ด์ ํ์
for x in range(n * 2):
for y in range(n * 2):
# ์๋ฌผ์ ์ ์ด์ ๋ฅผ ๋ผ์ ๋ฃ๊ธฐ
for i in range(m):
for j in range(m):
new_lock[x + i][y + j] += key[i][j]
# ์๋ก์ด ์๋ฌผ์ ์ ์ด์ ๊ฐ ์ ํํ ๋ค์ด ๋ง๋์ง ๊ฒ์ฌ
if check(new_lock) == True:
return True
# ์๋ฌผ์ ์์ ์ด์ ๋ฅผ ๋ค์ ๋นผ๊ธฐ
for i in range(m):
for j in range(m):
new_lock[x + i][y + j] -= key[i][j]
return False