coding test/leetCode

[leetCode/JS] 739. Daily Temperatures

쭘봉 2022. 12. 18. 10:21

난이도 [ 🤔 ] Medium

 

 

문제 설명

Given an array of integers temperatures represents the daily temperatures, return an array answer such that answer[i] is the number of days you have to wait after the ith day to get a warmer temperature. If there is no future day for which this is possible, keep answer[i] == 0 instead.

일일 온도가 입력된 배열에서 더 따듯해지는 날까지의 일 수의 배열을 반환하면된다. 없으면 0으로 리턴한다.

 

 

 

입출력 예

Example 1:

Input: temperatures = [73,74,75,71,69,72,76,73]
Output: [1,1,4,2,1,1,0,0]

 

Example 2:

Input: temperatures = [30,40,50,60]
Output: [1,1,1,0]

 

Example 3:

Input: temperatures = [30,60,90]
Output: [1,1,0]

 

 

 

 

Constraints

  • 1 <= temperatures.length <= 105
  • 30 <= temperatures\[i\] <= 100

 


 

내 솔루션

  • 그냥 순회해서 index 찾아서 index 리턴해서 끝낼라 했는데...
  • Time Limit에 걸리고 beats 5%로 엄청 느렸다.
// Time Limit
var dailyTemperatures = function(temperatures) {
  const answer = [];
  for(let i = 0; i < temperatures.length; i++) {
    const index = temperatures.slice(i+1).findIndex(t => temperatures[i] < t) + 1;
    answer.push(index);
  }
  return answer;
};


// Runtime 8683ms, beats 5%
var dailyTemperatures = function(temperatures) {
  const answer = [];
  for(let i = 0; i < temperatures.length; i++) {
    for(let j = i; j < temperatures.length; j++) {
      if(temperatures[i] < temperatures[j]) {
        answer.push(j-i);
        break;
      } else if ( j === temperatures.length - 1){
        answer.push(0);
      }
    }
  }
  return answer;
};

 

 

  • 결국엔 검색시작! 2포인트 서치나 스택에 쌓는 방법을 사용했더라..
  • 이해하기 쉬운건 스택을 이용한 탐색인데, 현재의 인덱스를 쌓아두고
  • 가장 최근에 쌓인 온도보다 높은 온도가 나오면 스택에 꺼내고 그 차이를 계산에서 입력하는 방식이다.
  • 말로는 어렵지만 코드를 보면 쉬웠다. 쥐엔장
var dailyTemperatures = function(temperatures) {
  const answer = Array(temperatures.length).fill(0);
  const stack = [];
  
  for(let i = 0; i < temperatures.length; i++) {
    let top = stack[stack.length-1];

    while(stack.length && temperatures[top] < temperatures[i]) {
      const idx = stack.pop();
      answer[idx] = i - idx;
      top = stack[stack.length-1];
    }
    stack.push(i);
  }
  return answer;
};

 

감상평

  • 이보다 더 느리게 할 수 있을까?
  • 다했다~ 싶을 때, 느려서 빠꾸먹으면 진짜 한숨이 ㅋㅋ