[백준]13305번 주유소 - 그리디

2021. 2. 3. 16:04·SW개발/코딩테스트

 

import sys

n = int(input())

length = list(map(int, sys.stdin.readline().split()))
oil = list(map(int, sys.stdin.readline().split()))
sum_ = 0
min_ = 0
for i in range(n - 1):
    if i == 0:
        sum_ = oil[0] * length[0]
        min_ = oil[0]
    else:
        min_ = min(min_, oil[i])
        sum_ = sum_ + min_ * length[i]
print(sum_)

 

코드 설명

길이와 기름 값 가격을 리스트에 저장하여 둔다. 반복문을 n-1 번 수행한다. 만약 맨 처음일 경우 첫 도로의 길이 * 첫 도시의 가격을 통해 기름을 넣어준다. 다음 도시에 도착하였을 때 기름 가격을 비교 한 후 더 싼 가격을 선택하여 도로의 길이만큼 또 전진한다. 

위와 같이 반복하며 정답을 구할 수 있다.

 

Point : 최솟값을 기억하는 방식을 이용한다. 도시를 이동해가며 적은 기름 가격을 매번 체크하면서 적은 양을 선택해서 기름을 넣도록 한다.

일반적인 상식과 달리 먼저 도시를 이동한 후 기름값을 지불하는 방식으로 생각하면 이해하기 쉽다.

728x90

'SW개발 > 코딩테스트' 카테고리의 다른 글

[백준]9184번 신나는 함수 실행 - DP  (0) 2021.02.05
[백준]1003번 피보나치 함수 - DP  (0) 2021.02.04
[백준]1449번 수리공 항승 - 그리디  (0) 2021.02.02
[백준]4796번 캠핑 - 그리디  (0) 2021.02.01
[백준]1339번 단어 수학 - 그리디  (0) 2021.01.31
'SW개발/코딩테스트' 카테고리의 다른 글
  • [백준]9184번 신나는 함수 실행 - DP
  • [백준]1003번 피보나치 함수 - DP
  • [백준]1449번 수리공 항승 - 그리디
  • [백준]4796번 캠핑 - 그리디
Leffe_pt
Leffe_pt
개발자로서 성장하면서 배워온 지식과 경험을 공유하는 공간입니다.
  • Leffe_pt
    Leffe's tistory
    Leffe_pt
  • 전체
    오늘
    어제
    • 분류 전체보기 (307)
      • SW개발 (303)
        • 코딩테스트 (172)
        • 개발이야기 (23)
        • IT 용어 (17)
        • Python (22)
        • Django (46)
        • Flask (2)
        • Database (1)
        • SQLAlchemy (0)
        • Javascript (5)
        • Linux, Unix (3)
        • JAVA (2)
        • Spring (10)
      • 회고 (4)
      • 사진 (0)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    컨트리뷰터
    django
    Contributor
    트리 #AVL #알고리즘 #자료구조
    배공파용
    오픈소스
    배달
    g
    라이프 스타일
    플레이스토어
    어플리케이션
    배달비 공유
    음식
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Leffe_pt
[백준]13305번 주유소 - 그리디
상단으로

티스토리툴바