문제
입력
maps:[String] = 지도 문자열
maps[i]
- "X" = 바다
- 숫자 = 무인도에 머물 수 있는 수
결과
ans: [Int] = 각 섬마다 최대 머물 수 있는 일 수 , 하나 없으면 [-1]
해석
X가 아니면 섬이므로 일단 들어가서 연결되어있는 모든 섬을 방문하여 숫자를 더한 다음 결과 배열에 담는다.
방문했는지 여부를 알아야하니 visited 배열필요
코드
import Foundation
extension String {
subscript(_ index: Int) -> String {
return String(self[self.index(self.startIndex, offsetBy: index)])
}
}
func solution(_ maps:[String]) -> [Int] {
let n = maps.count
let m = maps[0].count
var ans: [Int] = []
var visited: [[Bool]] = [[Bool]](repeating: [Bool](repeating: false, count:m), count: n)
let dx: [Int] = [0,0,-1,1]
let dy: [Int] = [1,-1,0,0]
func dfs(_ x:Int, _ y:Int) -> Int {
visited[x][y] = true
var sum = 0
for i in 0..<4 {
let nx = x + dx[i]
let ny = y + dy[i]
if nx < 0 || nx >= n || ny < 0 || ny >= m { continue }
if visited[nx][ny] || maps[nx][ny] == "X" { continue }
sum += dfs(nx,ny)
}
return Int(maps[x][y])! + sum
}
for i in 0..<n {
for j in 0..<m {
if maps[i][j] != "X" && !visited[i][j] {
ans.append(dfs(i,j))
}
}
}
return ans.isEmpty ? [-1] : ans.sorted()
}
'PS > 프로그래머스' 카테고리의 다른 글
[백준] 16916 부분 문자열 (0) | 2024.10.18 |
---|---|
[프로그래머스] 미로 탈출 (0) | 2024.10.04 |
[프로그래머스] 택배상자 (2) | 2024.10.02 |
[프로그래머스] n + 1 카드게임 (0) | 2024.10.01 |
[프로그래머스] 산 모양 타일링 (0) | 2024.10.01 |