yuns

[Lv2] 주식 가격 본문

algorithms/programmers

[Lv2] 주식 가격

yuuuun 2020. 11. 19. 23:06
반응형

문제 설명

초 단위로 기록된 주식가격이 담긴 배열 prices가 매개변수로 주어질 때, 가격이 떨어지지 않은 기간은 몇 초인지를 return 하도록 solution 함수를 완성하세요.

제한사항

  • prices의 각 가격은 1 이상 10,000 이하인 자연수입니다.
  • prices의 길이는 2 이상 100,000 이하입니다.

입출력 예

prices return
[1, 2, 3, 2, 3] [4, 3, 1, 1, 0]

입출력 예 설명

  • 1초 시점의 ₩1은 끝까지 가격이 떨어지지 않았습니다.
  • 2초 시점의 ₩2은 끝까지 가격이 떨어지지 않았습니다.
  • 3초 시점의 ₩3은 1초뒤에 가격이 떨어집니다. 따라서 1초간 가격이 떨어지지 않은 것으로 봅니다.
  • 4초 시점의 ₩2은 1초간 가격이 떨어지지 않았습니다.
  • 5초 시점의 ₩3은 0초간 가격이 떨어지지 않았습니다.
def solution(prices):
    answer = []
    for i in range(len(prices) - 1):
        cnt = 0
        for j in range(i + 1, len(prices)):
            cnt += 1
            if prices[i] > prices[j]:
                break
        answer.append(cnt)
    answer.append(0)
    return answer
  • [0, n-1]까지는 바로 다음에 주식 가격이 감소해도 가격이 1초동안 떨어진 것으로 고려하기 때문에 시작부터 1을 증가시키고 값을 비교한다.
  • 현재 시점에서 다른 시점들까지 가격이 감소하기 시작하면 break문을 통하여 for문을 빠져나가게 된다.
  • 마지막 주식의 값은 비교 대상이 없기 때문에 0을 추가해주고 결과를 도출해낸다.

반응형

'algorithms > programmers' 카테고리의 다른 글

[3차] 압축 파이썬 python3  (0) 2022.05.24
[Lv2] [카카오 인턴] 수식 최대화  (0) 2020.11.19
Comments