[프로그래머스/Python] 주식가격

고운·2024년 2월 27일

알고리즘

목록 보기
40/94

문제 설명

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

제한사항

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

입출력 예

pricesreturn
[1, 2, 3, 2, 3][4, 3, 1, 1, 0]

입출력 예 설명

  • 1초 시점의 ₩1은 끝까지 가격이 떨어지지 않았습니다.
  • 2초 시점의 ₩2은 끝까지 가격이 떨어지지 않았습니다.
  • 3초 시점의 ₩3은 1초뒤에 가격이 떨어집니다. 따라서 1초간 가격이 떨어지지 않은 것으로 봅니다.
  • 4초 시점의 ₩2은 1초간 가격이 떨어지지 않았습니다.
  • 5초 시점의 ₩3은 0초간 가격이 떨어지지 않았습니다.

풀이
prices의 길이가 2 이상 100,000 이하라는 조건때문에 완전탐색은 O(n2)O(n^2)이라서 생각도 못하고 있었다
이렇다 할 좋은 생각이 잘 안나서 알아보니 완전탐색을 써도 효율성 채점이 통과가 된다고 한다
그래서 그냥 완전탐색으로 풀어봤다
단순히 현재의 값보다 작은 값을 만날때까지 loop를 돈다
1초 뒤에 가격이 떨어지는 것이기 때문에 cnt를 +1 해주는 것만 유의하면 된다

코드

def solution(prices):
    answer = []
    for i in range(len(prices)):
        cnt = 0
        for j in range(i+1, len(prices)):
            if prices[i] <= prices[j]:
                cnt += 1
            else:
                cnt += 1
                break
        answer.append(cnt)
        
    return answer
profile
무럭무럭 성장하는 개린이 공부 공간

0개의 댓글