๋ฌธ์ ์ค๋ช
์ฝ๋ฉํ ์คํธ๋ฅผ ์ค๋นํ๋ ๋จธ์ฑ์ด๋ ํ๋ก๊ทธ๋๋จธ์ค์์ ๋ฌธ์ ๋ฅผ ํ๊ณ ๋์ค์ ๋ค์ ์ฝ๋๋ฅผ ๋ณด๋ฉด์ ๊ณต๋ถํ๋ ค๊ณ ์์ฑํ ์ฝ๋๋ฅผ ์ปดํจํฐ ๋ฐํํ๋ฉด์ ์๋ฌด ์์น์๋ ์ ์ฅํด ๋ก๋๋ค. ์ ์ฅํ ์ฝ๋๊ฐ ๋ง์์ง๋ฉด์ ๋จธ์ฑ์ด๋ ๋ณธ์ธ์ ์ปดํจํฐ ๋ฐํํ๋ฉด์ด ๋๋ฌด ์ง์ ๋ถํ๋ค๊ณ ์๊ฐํ์ต๋๋ค. ํ๋ก๊ทธ๋๋จธ์ค์์ ์์ฑํ๋ ์ฝ๋๋ ๊ทธ ๋ฌธ์ ์ ๊ฐ์ ๋ค์ ๋ณผ ์ ์๊ธฐ ๋๋ฌธ์ ์ ์ฅํด ๋ ํ์ผ๋ค์ ์ ๋ถ ์ญ์ ํ๊ธฐ๋ก ํ์ต๋๋ค.
์ปดํจํฐ ๋ฐํํ๋ฉด์ ๊ฐ ์นธ์ด ์ ์ฌ๊ฐํ์ธ ๊ฒฉ์ํ์ ๋๋ค. ์ด๋ ์ปดํจํฐ ๋ฐํํ๋ฉด์ ์ํ๋ฅผ ๋ํ๋ธ ๋ฌธ์์ด ๋ฐฐ์ด wallpaper๊ฐ ์ฃผ์ด์ง๋๋ค. ํ์ผ๋ค์ ๋ฐํํ๋ฉด์ ๊ฒฉ์์นธ์ ์์นํ๊ณ ๋ฐํํ๋ฉด์ ๊ฒฉ์์ ๋ค์ ๋ฐํํ๋ฉด์ ๊ฐ์ฅ ์ผ์ชฝ ์๋ฅผ (0, 0)์ผ๋ก ์์ํด (์ธ๋ก ์ขํ, ๊ฐ๋ก ์ขํ)๋ก ํํํฉ๋๋ค. ๋น์นธ์ ".", ํ์ผ์ด ์๋ ์นธ์ "#"์ ๊ฐ์ ๊ฐ์ง๋๋ค. ๋๋๊ทธ๋ฅผ ํ๋ฉด ํ์ผ๋ค์ ์ ํํ ์ ์๊ณ , ์ ํ๋ ํ์ผ๋ค์ ์ญ์ ํ ์ ์์ต๋๋ค. ๋จธ์ฑ์ด๋ ์ต์ํ์ ์ด๋๊ฑฐ๋ฆฌ๋ฅผ ๊ฐ๋ ํ ๋ฒ์ ๋๋๊ทธ๋ก ๋ชจ๋ ํ์ผ์ ์ ํํด์ ํ ๋ฒ์ ์ง์ฐ๋ ค๊ณ ํ๋ฉฐ ๋๋๊ทธ๋ก ํ์ผ๋ค์ ์ ํํ๋ ๋ฐฉ๋ฒ์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.
- ๋๋๊ทธ๋ ๋ฐํํ๋ฉด์ ๊ฒฉ์์ S(lux, luy)๋ฅผ ๋ง์ฐ์ค ์ผ์ชฝ ๋ฒํผ์ผ๋ก ํด๋ฆญํ ์ํ๋ก ๊ฒฉ์์ E(rdx, rdy)๋ก ์ด๋ํ ๋ค ๋ง์ฐ์ค ์ผ์ชฝ ๋ฒํผ์ ๋ผ๋ ํ๋์ ๋๋ค. ์ด๋, "์ S์์ ์ E๋ก ๋๋๊ทธํ๋ค"๊ณ ํํํ๊ณ ์ S์ ์ E๋ฅผ ๊ฐ๊ฐ ๋๋๊ทธ์ ์์์ , ๋์ ์ด๋ผ๊ณ ํํํฉ๋๋ค.
- ์ S(lux, luy)์์ ์ E(rdx, rdy)๋ก ๋๋๊ทธ๋ฅผ ํ ๋, "๋๋๊ทธ ํ ๊ฑฐ๋ฆฌ"๋ |rdx - lux| + |rdy - luy|๋ก ์ ์ํฉ๋๋ค.
- ์ S์์ ์ E๋ก ๋๋๊ทธ๋ฅผ ํ๋ฉด ๋ฐํํ๋ฉด์์ ๋ ๊ฒฉ์์ ์ ๊ฐ๊ฐ ์ผ์ชฝ ์, ์ค๋ฅธ์ชฝ ์๋๋ก ํ๋ ์ง์ฌ๊ฐํ ๋ด๋ถ์ ์๋ ๋ชจ๋ ํ์ผ์ด ์ ํ๋ฉ๋๋ค.
์๋ฅผ ๋ค์ด wallpaper = [".#...", "..#..", "...#."]์ธ ๋ฐํํ๋ฉด์ ๊ทธ๋ฆผ์ผ๋ก ๋ํ๋ด๋ฉด ๋ค์๊ณผ ๊ฐ์ต๋๋ค.
์ด๋ฌํ ๋ฐํํ๋ฉด์์ ๋ค์ ๊ทธ๋ฆผ๊ณผ ๊ฐ์ด S(0, 1)์์ E(3, 4)๋ก ๋๋๊ทธํ๋ฉด ์ธ ๊ฐ์ ํ์ผ์ด ๋ชจ๋ ์ ํ๋๋ฏ๋ก ๋๋๊ทธ ํ ๊ฑฐ๋ฆฌ (3 - 0) + (4 - 1) = 6์ ์ต์๊ฐ์ผ๋ก ๋ชจ๋ ํ์ผ์ ์ ํ ๊ฐ๋ฅํฉ๋๋ค.
(0, 0)์์ (3, 5)๋ก ๋๋๊ทธํด๋ ๋ชจ๋ ํ์ผ์ ์ ํํ ์ ์์ง๋ง ์ด๋ ๋๋๊ทธ ํ ๊ฑฐ๋ฆฌ๋ (3 - 0) + (5 - 0) = 8์ด๊ณ ์ด์ ์ ๋ฐฉ๋ฒ๋ณด๋ค ๊ฑฐ๋ฆฌ๊ฐ ๋์ด๋ฉ๋๋ค.
๋จธ์ฑ์ด์ ์ปดํจํฐ ๋ฐํํ๋ฉด์ ์ํ๋ฅผ ๋ํ๋ด๋ ๋ฌธ์์ด ๋ฐฐ์ด wallpaper๊ฐ ๋งค๊ฐ๋ณ์๋ก ์ฃผ์ด์ง ๋ ๋ฐํํ๋ฉด์ ํ์ผ๋ค์ ํ ๋ฒ์ ์ญ์ ํ๊ธฐ ์ํด ์ต์ํ์ ์ด๋๊ฑฐ๋ฆฌ๋ฅผ ๊ฐ๋ ๋๋๊ทธ์ ์์์ ๊ณผ ๋์ ์ ๋ด์ ์ ์ ๋ฐฐ์ด์ returnํ๋ solution ํจ์๋ฅผ ์์ฑํด ์ฃผ์ธ์. ๋๋๊ทธ์ ์์์ ์ด (lux, luy), ๋์ ์ด (rdx, rdy)๋ผ๋ฉด ์ ์ ๋ฐฐ์ด [lux, luy, rdx, rdy]๋ฅผ returnํ๋ฉด ๋ฉ๋๋ค.
์ ํ ์ฌํญ
- 1 ≤ wallpaper์ ๊ธธ์ด ≤ 50
- 1 ≤ wallpaper[i]์ ๊ธธ์ด ≤ 50
- wallpaper์ ๋ชจ๋ ์์์ ๊ธธ์ด๋ ๋์ผํฉ๋๋ค.
- wallpaper[i][j]๋ ๋ฐํํ๋ฉด์์ i + 1ํ j + 1์ด์ ํด๋นํ๋ ์นธ์ ์ํ๋ฅผ ๋ํ๋ ๋๋ค.
- wallpaper[i][j]๋ "#" ๋๋ "."์ ๊ฐ๋ง ๊ฐ์ง๋๋ค.
- ๋ฐํํ๋ฉด์๋ ์ ์ด๋ ํ๋์ ํ์ผ์ด ์์ต๋๋ค.
- ๋๋๊ทธ ์์์ (lux, luy)์ ๋์ (rdx, rdy)๋ lux < rdx, luy < rdy๋ฅผ ๋ง์กฑํด์ผ ํฉ๋๋ค.
์ ์ถ๋ ฅ ์
wallpaper | result |
[".#...", "..#..", "...#."] | [0, 1, 3, 4] |
["..........", ".....#....", "......##..", "...##.....", "....#....."] | [1, 3, 5, 8] |
[".##...##.", "#..#.#..#", "#...#...#", ".#.....#.", "..#...#..", "...#.#...", "....#...."] | [0, 0, 7, 9] |
["..", "#."] | [1, 0, 2, 1] |
์ ์ถ๋ ฅ ์ ์ค๋ช
์ ์ถ๋ ฅ ์ #1
- ๋ฌธ์ ์ค๋ช ์ ์์์ ๊ฐ์ ์์ ์ ๋๋ค. (0, 1)์์ (3, 4)๋ก ๋๋๊ทธ ํ๋ฉด ๋ชจ๋ ํ์ผ์ ์ ํํ ์ ์๊ณ ๋๋๊ทธ ํ ๊ฑฐ๋ฆฌ๋ 6์ด์๊ณ , 6๋ณด๋ค ์ ์ ๊ฑฐ๋ฆฌ๋ก ๋ชจ๋ ํ์ผ์ ์ ํํ๋ ๋ฐฉ๋ฒ์ ์์ต๋๋ค. ๋ฐ๋ผ์ [0, 1, 3, 4]๋ฅผ returnํฉ๋๋ค.
์ ์ถ๋ ฅ ์ #2
- ์์ 2๋ฒ์ ๋ฐํํ๋ฉด์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.(1, 3)์์ (5, 8)๋ก ๋๋๊ทธํ๋ฉด ๋ชจ๋ ํ์ผ์ ์ ํํ ์ ์๊ณ ์ด๋ณด๋ค ์ ์ ์ด๋๊ฑฐ๋ฆฌ๋ก ๋ชจ๋ ํ์ผ์ ์ ํํ๋ ๋ฐฉ๋ฒ์ ์์ต๋๋ค. ๋ฐ๋ผ์ ๊ฐ์ฅ ์ ์ ์ด๋์ ๋๋๊ทธ๋ก ๋ชจ๋ ํ์ผ์ ์ ํํ๋ ๋ฐฉ๋ฒ์ธ [1, 3, 5, 8]์ returnํฉ๋๋ค.
์ ์ถ๋ ฅ ์ #3
- ์์ 3๋ฒ์ ๋ฐํํ๋ฉด์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.๋ชจ๋ ํ์ผ์ ์ ํํ๊ธฐ ์ํด์ ๋ฐํํ๋ฉด์ ๊ฐ์ฅ ์ผ์ชฝ ์ (0, 0)์์ ๊ฐ์ฅ ์ค๋ฅธ์ชฝ ์๋ (7, 9)๋ก ๋๋๊ทธ ํด์ผ๋ง ํฉ๋๋ค. ๋ฐ๋ผ์ [0, 0, 7, 9]๋ฅผ returnํฉ๋๋ค.
์ ์ถ๋ ฅ ์ #4
- ์์ 4๋ฒ์ ๋ฐํํ๋ฉด์ ๋ค์๊ณผ ๊ฐ์ด 2ํ 1์ด์๋ง ์์ด์ฝ์ด ์์ต๋๋ค.์ด๋ฅผ ๋๋๊ทธ๋ก ์ ํํ๊ธฐ ์ํด์๋ ๊ทธ ์นธ์ ์ผ์ชฝ ์ (1, 0)์์ ์ค๋ฅธ์ชฝ ์๋ (2, 1)๋ก ๋๋๊ทธ ํ๋ฉด ๋ฉ๋๋ค. (1, 0)์์ (2, 2)๋ก ๋๋๊ทธ ํด๋ ์์ด์ฝ์ ์ ํํ ์ ์์ง๋ง ์ด์ ๋ณด๋ค ์ด๋๊ฑฐ๋ฆฌ๊ฐ ๋์ด๋ฉ๋๋ค. ๋ฐ๋ผ์ [1, 0, 2, 1]์ returnํฉ๋๋ค.
ํ์ด
- ๋์ ํ์ด (์ค๋๋ ๋ฌด์ง์ฑ 1๊ฑด ํ๋ค ใ
ใ
ใ
)
- ๊ทธ๋ฆฌ๊ณ ์ฌ์ ํ x,y ์ขํ๋ฅผ ๋ฐ๋๋ก ์ถ์ ํ๋ค...
def solution(wallpaper):
answer = [0] * 4
screen_width = len(wallpaper[0])
screen_height = len(wallpaper)
answer[0] = screen_height
answer[1] = screen_width
answer[2] = 0
answer[3] = 0
for y in range(screen_height):
for x in range(screen_width):
if wallpaper[y][x] == "#":
if answer[0] > y:
answer[0] = y
if answer[1] > x:
answer[1] = x
if answer[2] < y:
answer[2] = y
if answer[3] < x:
answer[3] = x
answer[2] += 1
answer[3] += 1
return answer
์ ํ์ฑ ํ
์คํธ
ํ
์คํธ 1 ใ ํต๊ณผ (0.02ms, 10.2MB)
ํ
์คํธ 2 ใ ํต๊ณผ (0.01ms, 10.2MB)
ํ
์คํธ 3 ใ ํต๊ณผ (0.01ms, 10.1MB)
ํ
์คํธ 4 ใ ํต๊ณผ (0.02ms, 10.2MB)
ํ
์คํธ 5 ใ ํต๊ณผ (0.02ms, 10.1MB)
ํ
์คํธ 6 ใ ํต๊ณผ (0.01ms, 10.2MB)
ํ
์คํธ 7 ใ ํต๊ณผ (0.12ms, 10.2MB)
ํ
์คํธ 8 ใ ํต๊ณผ (0.10ms, 10.2MB)
ํ
์คํธ 9 ใ ํต๊ณผ (0.20ms, 10.2MB)
ํ
์คํธ 10 ใ ํต๊ณผ (0.13ms, 10.2MB)
ํ
์คํธ 11 ใ ํต๊ณผ (0.05ms, 10.1MB)
ํ
์คํธ 12 ใ ํต๊ณผ (0.05ms, 10.1MB)
ํ
์คํธ 13 ใ ํต๊ณผ (0.08ms, 10.2MB)
ํ
์คํธ 14 ใ ํต๊ณผ (0.05ms, 10.1MB)
ํ
์คํธ 15 ใ ํต๊ณผ (0.08ms, 10.1MB)
ํ
์คํธ 16 ใ ํต๊ณผ (0.11ms, 10.2MB)
ํ
์คํธ 17 ใ ํต๊ณผ (0.06ms, 10.2MB)
ํ
์คํธ 18 ใ ํต๊ณผ (0.29ms, 10.2MB)
ํ
์คํธ 19 ใ ํต๊ณผ (0.11ms, 10.4MB)
ํ
์คํธ 20 ใ ํต๊ณผ (0.14ms, 10.2MB)
ํ
์คํธ 21 ใ ํต๊ณผ (0.01ms, 10.1MB)
ํ
์คํธ 22 ใ ํต๊ณผ (0.01ms, 10.2MB)
ํ
์คํธ 23 ใ ํต๊ณผ (0.03ms, 10.1MB)
ํ
์คํธ 24 ใ ํต๊ณผ (0.02ms, 10.1MB)
ํ
์คํธ 25 ใ ํต๊ณผ (0.19ms, 10.1MB)
ํ
์คํธ 26 ใ ํต๊ณผ (0.11ms, 10.2MB)
ํ
์คํธ 27 ใ ํต๊ณผ (0.06ms, 10.2MB)
ํ
์คํธ 28 ใ ํต๊ณผ (0.04ms, 9.95MB)
ํ
์คํธ 29 ใ ํต๊ณผ (0.06ms, 10MB)
ํ
์คํธ 30 ใ ํต๊ณผ (0.35ms, 10.2MB)
ํ
์คํธ 31 ใ ํต๊ณผ (0.14ms, 10.2MB)
- ๊ณ ์์ ํ์ด. ๊น๋ํ๊ตฌ๋...
def solution(wall):
a, b = [], []
for i in range(len(wall)):
for j in range(len(wall[i])):
if wall[i][j] == "#":
a.append(i)
b.append(j)
return [min(a), min(b), max(a) + 1, max(b) + 1]
์ ํ์ฑ ํ
์คํธ
ํ
์คํธ 1 ใ ํต๊ณผ (0.01ms, 10MB)
ํ
์คํธ 2 ใ ํต๊ณผ (0.01ms, 10.2MB)
ํ
์คํธ 3 ใ ํต๊ณผ (0.01ms, 10.1MB)
ํ
์คํธ 4 ใ ํต๊ณผ (0.02ms, 10MB)
ํ
์คํธ 5 ใ ํต๊ณผ (0.02ms, 10.2MB)
ํ
์คํธ 6 ใ ํต๊ณผ (0.01ms, 10.2MB)
ํ
์คํธ 7 ใ ํต๊ณผ (0.09ms, 10.1MB)
ํ
์คํธ 8 ใ ํต๊ณผ (0.19ms, 10MB)
ํ
์คํธ 9 ใ ํต๊ณผ (0.23ms, 10.1MB)
ํ
์คํธ 10 ใ ํต๊ณผ (0.09ms, 10.2MB)
ํ
์คํธ 11 ใ ํต๊ณผ (0.07ms, 10.1MB)
ํ
์คํธ 12 ใ ํต๊ณผ (0.11ms, 10.1MB)
ํ
์คํธ 13 ใ ํต๊ณผ (0.04ms, 9.93MB)
ํ
์คํธ 14 ใ ํต๊ณผ (0.06ms, 10.2MB)
ํ
์คํธ 15 ใ ํต๊ณผ (0.08ms, 10.1MB)
ํ
์คํธ 16 ใ ํต๊ณผ (0.29ms, 10.4MB)
ํ
์คํธ 17 ใ ํต๊ณผ (0.06ms, 10.1MB)
ํ
์คํธ 18 ใ ํต๊ณผ (0.16ms, 10.2MB)
ํ
์คํธ 19 ใ ํต๊ณผ (0.11ms, 10.1MB)
ํ
์คํธ 20 ใ ํต๊ณผ (0.27ms, 10.1MB)
ํ
์คํธ 21 ใ ํต๊ณผ (0.01ms, 10.3MB)
ํ
์คํธ 22 ใ ํต๊ณผ (0.01ms, 10MB)
ํ
์คํธ 23 ใ ํต๊ณผ (0.03ms, 10.2MB)
ํ
์คํธ 24 ใ ํต๊ณผ (0.02ms, 10.3MB)
ํ
์คํธ 25 ใ ํต๊ณผ (0.12ms, 10.3MB)
ํ
์คํธ 26 ใ ํต๊ณผ (0.12ms, 10MB)
ํ
์คํธ 27 ใ ํต๊ณผ (0.11ms, 10.1MB)
ํ
์คํธ 28 ใ ํต๊ณผ (0.04ms, 10MB)
ํ
์คํธ 29 ใ ํต๊ณผ (0.06ms, 10.1MB)
ํ
์คํธ 30 ใ ํต๊ณผ (0.32ms, 10.2MB)
ํ
์คํธ 31 ใ ํต๊ณผ (0.30ms, 10.1MB)
์ขํ๋ง ์ ๋๋ก ์จ์ฃผ๋ฉด ์๊ฐ ๋ญ๋น ์ํ์ํ ๋ฐ...