코딩테스트/프로그래머스
[프로그래머스] 주식가격(Java)
Jindory
2022. 7. 30. 22:25
반응형
문제설명
초 단위로 기록된 주식가격이 담긴 배열 prices가 매개변수로 주어질 때, 가격이 떨어지지 않은 기간은 몇 초인지를 return 하도록 solution 함수를 완성하세요.
제한사항
- prices의 각 가격은 1 이상 10,000 이하인 자연수입니다.
- prices의 길이는 2 이상 100,000 이하입니다.
전체코드(Java)
import java.util.*;
import java.util.stream.*;
class Solution {
public int[] solution(int[] prices) {
int[] answer = new int[prices.length];
Stack<Integer> s = new Stack<>();
// 가장 처음 값을 stack 우선 넣는다.
s.push(0);
// 비교하는 값보다 큰 값이 stack 상위에 존재한다면, 현재위치에서 해당 위치의 차이를 answer에 저장한다.
for(int i=1;i<prices.length;i++){
// stack이 비어있지 않고 스택의 꼭대기 값 인덱스에 위치한 price가 현재 값보다 크다면, 현재위치에서 해당 위치의 차이를 answer에 저장 후 stack에서 제거
while(!s.isEmpty()&&prices[s.peek()]>prices[i]){
answer[s.peek()] = i-s.peek();
s.pop();
}
// 비교하는 값의 index를 추가한다.
s.push(i);
}
// stack에 있는 index를 순회하며, 주식가격이 떨어지지 않은 기간을 answer에 저장한다.
for(int i=s.size();i>0;i--){
answer[s.peek()] = prices.length-s.peek()-1;
s.pop();
}
return answer;
}
}
혹시라도 정정할 내용이나 추가적으로 필요하신 정보가 있다면 댓글 남겨주시면 감사하겠습니다.
오늘도 Jindory 블로그에 방문해주셔서 감사합니다.
반응형