D.evelop [CS]/Algorithm

[Algorithm 015] JS - maxProfit

Danne 2021. 10. 12. 23:45

Q.  prices는 배열이며, 각 요소는 매일의 주식 가격입니다. 만약 한 번만 거래할 수 있다면 = 사고 팔 수 있다면, 제일 큰 이익은 얼마일까요?

  • 설명: 2일(가격=1)에 샀다가 5일(가격=6)에 사는 것이 6-1이라 제일 큰 수익 7-1=6 은 안 되는거 아시죠? 먼저 사야 팔 수 있습니다.
Input: [7,1,5,3,6,4]
Output: 5
  • 설명: 여기서는 매일 가격이 낮아지기 때문에 거래가 없습니다. 그래서 0
Input: [7,6,4,3,1]
Output: 0

 

 

 

A.  답

const maxProfit = prices => {
  const arr = [];
  for ( i = 0 ; i < prices.length ; i++ ){
    for ( j = 1 ; j < prices.length ; j++ ){
    
     if( i < j && prices[i] < prices[j] ){
       arr.push( prices[j] - prices[i] )
     }
     
    }
  }
  return arr.length > 0 ? Math.max(...arr) : 0
};

maxProfit([7,1,5,3,6,4])    // 5

1. 배열의 각 index값이 중복되지 않게 비교한다.

2. 주식을 사야 팔수 있기 때문에 i를 산 날이라 가정하고 i가 j보다 빠를 때, 즉 첫 인덱스(i)가 두 번째(j) 보다 작아햐한다.

3. 값이 낮을 때사고 비쌀 때 팔아야 이득이므로 산 날의 값(prices[i])이 판 날의 값(prices[j])보다 작아야한다.

4. 2, 3을 만족하는 값을 새로운 배열 arr에 push한다.

5. 수익이 나지 않았을 때는 0을 return할 수 있게한다.

- 빈 배열 []은 Truthy(boolean에서 true)값이므로 length값을 사용해 false값을 구분한다.

 

 

 

 

 

 

 

반응형