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
- 백준
- 전자 메일
- 사과 담기 게임
- 위치 암호화
- 욱제는 효도쟁이야!!
- 대체 암호화
- 파이썬
- 한빛미디어
- DES 알고리즘
- 비연결형 통신
- JoCoding
- 컴퓨터 네트워크
- 컬럼 암호화
- 나동빈
- 문자 변환표
- 동적 계획 알고리즘
- 그리디 알고리즘
- 거스름돈
- 키워드 암호화
- 5와 6의 차이
- 시저 암호화
- 2 + 1 세일
- 소가 길을 건너간 이유3
- 세탁소 사장 동혁
- ZOAC 2
- 구현
- Pop
- 통나무 건너기
- Greedy
- 코딩 테스트
Archives
- Today
- Total
주니어로서의 백 걸음, 개발자로서의 한 걸음
[백준 2828] 사과 담기 게임 파이썬 문제 풀이 본문
문제 풀이: 해당 문제는 3가지 경우로 나누어서 생각할 수 있다.
1. 사과가 d(현재 위치) ~ m(바구니 크기) - 1 사이에 떨어지는 경우 -> 움직일 필요가 없으므로 pass
2. 사과가 d보다 왼쪽에 있는 경우 -> 사과가 떨어지는 지점까지 바구니가 왼쪽으로 이동해야 함
3. 나머지 모든 경우 -> 현재 위치를 기준으로 m - 1이 사과가 떨어지는 지점까지 이동해야 함
n, m = map(int, input().split())
a = int(input())
apples = []
d = 1
result = 0
for _ in range(a):
apples.append(int(input()))
for apple in apples:
if apple >= d and apple <= d + (m - 1):
pass
elif d > apple:
result += abs(apple - d)
d = apple
else:
result += apple - (m - 1) - d
d = apple - (m - 1)
print(result)
'Python > 백준 문제풀이' 카테고리의 다른 글
[백준 18238] ZOAC 2 파이썬 문제 풀이 (0) | 2023.07.26 |
---|---|
[백준 11508] 2 + 1 세일 파이썬 문제 풀이 (0) | 2023.07.24 |
[백준 13904] 과제 파이썬 문제 풀이 (0) | 2023.07.23 |
[백준 11497] 통나무 건너기 파이썬 문제 풀이 (0) | 2023.07.22 |
[백준 2810] 컵홀더 파이썬 문제 풀이 (0) | 2023.07.22 |