Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- gcc 업데이트
- python popen
- 백준
- 1697
- centos pyhon 설치
- c3 축 없애기
- python subprocess
- selinux port 등록
- c3 초
- grafana dashboard
- c3 step graph
- telegraf
- snmp
- semanage
- regex_search
- 정규식 문자열 출력
- gcc regex
- influxdb 설치
- c3 축 가리기
- CentOS7
- linux시간으로 변경
- c3 second
- 정규식 활용
- g++ 업데이트
- snmp test
- subporcess path
- InfluxDB
- 정규식 컴파일
- c++ 정규식
- python os
Archives
- Today
- Total
리셋 되지 말자
[백준 2839] 설탕배달 - 수학, DP, 그리디 본문
코드
def solution(n):
cnt_5 = n//5
while cnt_5 != 0:
if (n - cnt_5*5)%3 == 0:
break
cnt_5 -= 1
if cnt_5 != 0:
return cnt_5 + (n - cnt_5*5)//3
else:
if n % 3 == 0:
return n // 3
else:
return -1
n = int(input())
print(solution(n))
설명
- 최대한 제일 적은 개수의 봉지로 배달을 해야한다
- 그러므로 5킬로그램 봉지를 최대한 많이 사용하되, 나누어 떨어지게 3킬로 그램 봉지를 사용해야 한다
- 5킬로그램 봉지를 최대로 잡고, 하나씩 줄이면서 3으로 나누어 떨어지는지 확인한다
- 나누어 떨어진다면 5킬로그램 봉지 개수와 3킬로그램 봉지 개수를 더한값을 출력한다
- 5킬로그램 봉지가 0개 인데, 3으로 나누어 떨어지지 않으면 정확하게 n킬로그램을 만들 수 없으므로 -1을 출력한다
'알고리즘' 카테고리의 다른 글
[백준 11050] 이항 계수 1 - 수학, 구현, 조합론 (0) | 2021.12.30 |
---|---|
[백준 2869] 달팽이는 올라가고 싶다 - 수학 (0) | 2021.12.29 |
[백준 15829] Hashing (0) | 2021.12.28 |
[백준 2775] 부녀회장이 될테야 - 수학 (0) | 2021.12.27 |
[백준 2292] 벌집 - 수열 (0) | 2021.12.27 |
Comments