ํ๋ก๊ทธ๋๋จธ์ค LV.1 ๋ชจ์
๋ฐํํ๋ฉด ์ ๋ฆฌ
๋ฌธ์ ์ค๋ช
์ฝ๋ฉํ ์คํธ๋ฅผ ์ค๋นํ๋ ๋จธ์ฑ์ด๋ ํ๋ก๊ทธ๋๋จธ์ค์์ ๋ฌธ์ ๋ฅผ ํ๊ณ ๋์ค์ ๋ค์ ์ฝ๋๋ฅผ ๋ณด๋ฉด์ ๊ณต๋ถํ๋ ค๊ณ ์์ฑํ ์ฝ๋๋ฅผ ์ปดํจํฐ ๋ฐํํ๋ฉด์ ์๋ฌด ์์น์๋ ์ ์ฅํด ๋ก๋๋ค. ์ ์ฅํ ์ฝ๋๊ฐ ๋ง์์ง๋ฉด์ ๋จธ์ฑ์ด๋ ๋ณธ์ธ์ ์ปดํจํฐ ๋ฐํํ๋ฉด์ด ๋๋ฌด ์ง์ ๋ถํ๋ค๊ณ ์๊ฐํ์ต๋๋ค. ํ๋ก๊ทธ๋๋จธ์ค์์ ์์ฑํ๋ ์ฝ๋๋ ๊ทธ ๋ฌธ์ ์ ๊ฐ์ ๋ค์ ๋ณผ ์ ์๊ธฐ ๋๋ฌธ์ ์ ์ฅํด ๋ ํ์ผ๋ค์ ์ ๋ถ ์ญ์ ํ๊ธฐ๋ก ํ์ต๋๋ค.
์ปดํจํฐ ๋ฐํํ๋ฉด์ ๊ฐ ์นธ์ด ์ ์ฌ๊ฐํ์ธ ๊ฒฉ์ํ์ ๋๋ค. ์ด๋ ์ปดํจํฐ ๋ฐํํ๋ฉด์ ์ํ๋ฅผ ๋ํ๋ธ ๋ฌธ์์ด ๋ฐฐ์ด 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 ํฉ๋๋ค.
์ ์ถ
import Foundation
func solution(_ wallpaper:[String]) -> [Int] {
var x_arr = [Int]()
var y_arr = [Int]()
for (i, paper) in wallpaper.enumerated() {
if paper.contains("#"){
for (index, w) in paper.map{String($0)}.enumerated(){
if w == "#" {
x_arr.append(i)
y_arr.append(index)
}
}
}
}
return [x_arr.min() ?? 0, y_arr.min() ?? 0, x_arr.max()!+1, y_arr.max()!+1]
}
wallpaper ๋ฐฐ์ด์ ์ด์ "#"์ด ์๋ ๊ฒฝ์ฐ์๋ง ์์ชฝ for๋ฌธ์ ์คํํ๋ค.
x_arr์๋ ์ด์ ๋ํ๋ด๋ i์ ๊ฐ์ ์ ์ฅํ๊ณ , y_arr์๋ ํ์ ๋ํ๋ด๋ index๊ฐ์ ์ ์ฅํ๋ค.
x_arr์์ ๊ฐ์ฅ ์์ ๊ฐ๊ณผ y_arr์์ ๊ฐ์ฅ ์์ ๊ฐ, x_arr์์ ๊ฐ์ฅ ํฐ ๊ฐ+1, y_arr์์ ๊ฐ์ฅ ํฐ ๊ฐ+1์ ๋ฐฐ์ด์ ๋ด์ ๋ฐํํ๋ค.
(๊ฐ ๋ฐฐ์ด์ ๊ฐ์ด ์๋ค๋ฉด 0์ ๋ด์ ๋ฐํํ๋ค.)
'โจ๏ธ Language > swift' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[Swift] ๋ฐฑ์ค 1158๋ฒ - ์์ธํธ์ค ๋ฌธ์ (0) | 2023.03.20 |
---|---|
[Swift] ๋ฐฑ์ค 18258๋ฒ - ํ 2 (0) | 2023.03.20 |
[Swift] ํ๋ก๊ทธ๋๋จธ์ค LV.1 ๋์ถฉ ๋ง๋ ์ํ (0) | 2023.03.19 |
[Swift] ๋ฐฑ์ค 9012๋ฒ - ๊ดํธ (0) | 2023.03.18 |
[Swift] ๋ฐฑ์ค 10828๋ฒ - ์คํ (0) | 2023.03.18 |