[SWEA] 1859번 - 백만장자 프로젝트

김멉덥·2023년 7월 1일
0

알고리즘 공부

목록 보기
13/171
post-thumbnail

문제

D2 - 1859. 백만 장자 프로젝트


코드 구현

정답 코드

# 입력
'''
T개의 테스트케이스
배열 len
배열
'''

T = int(input())
N = 0
for t in range(T):
    # 입력받기
    N = int(input())
    nums = list(map(int, input().split()))

    # 최대 이익 얻기
    # 제일 큰 매매가와 그 매매가의 인덱스 찾기 -> 최대 이익 계산
    max_element = nums[-1]  # 배열의 최대값
    max_index = -1          # 최대값이 위치한 인덱스
    max_profit = 0          # 최대 이익값 (출력할 정답)
    for i in range(N-2, -1, -1):    # 뒤에서부터 거꾸로 따져보기
        if (nums[i] >= max_element):    # 만약 최대값이 마지막 인덱스가 아니라 i번째 요소라면
            max_element = nums[i]       # 최대값 업데이트
            max_index = i
        else:       # 최대값이 i번째 요소가 아니라면 -> 현재 얻을 이익 계산하기
            profit = max_element - nums[i]  # 최대값 - 현재 매매가
            max_profit += profit            # 최대 이익값에 현재 얻을 수 있는 이익 더해서 업데이트

    # 첫쨋날이 제일 큰 매매가일 경우 -> 최대 이익은 없음
    if (max_index == 0):
        max_profit = 0

    print("#%ld %ld" % (t + 1, max_profit))

풀이

  • 뒤에서부터 거꾸로 계산하며 업데이트 해주어야 한다.
  • 마지막날의 매매가를 우선 최대값으로 설정 → 뒤에서부터 거슬러오며 각각의 매매가를 비교
  • i번째의 매매가가 현재 최대값보다 크면 → 최대값을 i번째 매매가로 변경
  • i번째의 매매가가 현재 최대값보다 작으면 → 현재 얻을 수 있는 이익 계산하기 (최대값 - 현재 매매가)

profile
데굴데굴 뚝딱뚝딱 개발기록

0개의 댓글