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;
}