Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- ChatGPT
- gs25
- 자연어처리
- 프로그래머스
- PYTHON
- 프로그래머스 파이썬
- hackerrank
- github
- 우분투
- leetcode
- ubuntu
- Baekjoon
- SW Expert Academy
- Real or Not? NLP with Disaster Tweets
- 편스토랑
- 금융문자분석경진대회
- Kaggle
- 파이썬
- AI 경진대회
- 편스토랑 우승상품
- 더현대서울 맛집
- Git
- 백준
- dacon
- 캐치카페
- Docker
- 코로나19
- 데이콘
- 맥북
- programmers
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 4821번 : 페이지 세기 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 백준의 페이지 세기 입니다.
👨🏻💻 문제 풀이
쉬워보여서 풀기 시작했는데 대충 풀었더니 IndexError 가 자꾸 발생했던 문제입니다.
IndexError는 주어지는 페이지가 책의 전체 페이지보다 더 큰 수가 주어지는 것에 대해서
예외 처리가 제대로 되지 않았기 때문에 발생했습니다.
문제를 풀면서 계속 IndexError가 발생한다면
- 내가 현재 참조하는 리스트보다 큰 값을 인덱스 값으로 쓰고 있지는 않은지?
- 예외처리를 확실히 다 했는지?
확인해보시기 바랍니다.
이 문제는 입력 받은 전체 페이지만큼의 0이 담긴 배열을 만들고
입력받은 페이지 정보를 인덱스로 삼아 해당 부분에 1을 넣은 뒤
마지막에 sum을 활용해 전체 페이지가 자연스럽게 카운팅 되도록 하였습니다.
전체 코드는 아래를 참고해주세요.
👨🏻💻 코드 ( Solution )
def counting_pages(total_page_num, input_page_info):
pages = [0 for _ in range(total_page_num + 1)]
page_info_list = input_page_info.split(",")
for page_info in page_info_list:
info = page_info.split("-")
if len(info) == 1 or len(set(info)) == 1:
if int(info[0]) < len(pages):
pages[int(info[0])] = 1
else:
min_page, max_page = map(int, info)
if (min_page > max_page) or (min_page > total_page_num):
continue
else:
for page in range(min_page, max_page+1):
if page < len(pages):
pages[page] = 1
return sum(pages)
if __name__ == "__main__":
while True:
total_page = int(input())
if total_page == 0:
break
input_page_info = input()
print(counting_pages(total_page, input_page_info))
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaekJoon] 23234번 : The World Responds (Python) (0) | 2022.05.19 |
---|---|
[BaekJoon] 1267번 : 핸드폰 요금 (Python) (0) | 2022.05.18 |
[BaekJoon] 15680번 : 연세대학교 (Python) (0) | 2022.05.16 |
[BaekJoon] 13866번 : 팀 나누기 (Python) (0) | 2022.05.15 |
[BaekJoon] 3003번 : 킹, 퀸, 룩, 비숍, 나이트, 폰 (Python) (0) | 2022.05.14 |
Comments