๐ ์ฝํ
/ํ๋ก๊ทธ๋๋จธ์ค
[Swift] ํ๋ก๊ทธ๋๋จธ์ค154539 ๋ค์ ์๋ ํฐ ์ ์ฐพ๊ธฐ
JerryiOS
2023. 5. 13. 12:01
import Foundation
func solution(_ numbers: [Int]) -> [Int] {
var stack = [Int]()
var res = Array(repeating: -1, count: numbers.count)
for i in 0..<numbers.count {
while !stack.isEmpty && numbers[stack.last!] < numbers[i] {
res[stack.removeLast()] = numbers[i]
}
stack.append(i)
}
return res
}
O(N)์ ์๊ฐ๋ณต์ก๋๋ก ํ์ด์ผ ์๊ฐ์ด๊ณผ๊ฐ ๋์ง ์๋๋ค.
์ํ๋ฅผ ํ๋ฒ๋ง ํ๊ธฐ ์ํด stack์ ์ด์ฉํ๋ค.
๋ฐ์ํ