Programmers
[프로그래머스][JS] 뒤에 있는 큰 수 찾기 ✅
winter17
2023. 9. 26. 22:18
https://school.programmers.co.kr/learn/courses/30/lessons/154539
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
풀이 과정
function solution(numbers) {
// numbers의 길이만큼 answer배열을 -1로 채워서 생성
var answer = new Array(numbers.length).fill(-1);
const stack = []
for (let i = 0; i < numbers.length; i++){
// stack 배열이 비어있지 않고,
// 현재 스택의 맨 위에 있는 인덱스가 가리키는 값이 현재 원소보다 작은지 확인
while(stack.length && numbers[stack[stack.length - 1]] < numbers[i]){
const smallerIndex = stack.pop()
answer[smallerIndex] = numbers[i]
}
stack.push(i) // stack배열에 인덱스 값을 push
}
return answer;
}