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 | 31 |
Tags
- SW Expert Academy
- 편스토랑 우승상품
- Kaggle
- hackerrank
- 백준
- gs25
- 자연어처리
- PYTHON
- 더현대서울 맛집
- dacon
- 코로나19
- Git
- 파이썬
- Docker
- 프로그래머스 파이썬
- 우분투
- ubuntu
- Real or Not? NLP with Disaster Tweets
- 편스토랑
- 캐치카페
- AI 경진대회
- programmers
- 맥북
- ChatGPT
- leetcode
- Baekjoon
- github
- 금융문자분석경진대회
- 데이콘
- 프로그래머스
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 25893번 : Majestic 10 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 백준의 Majestic 10 입니다.
👨🏻💻 문제 풀이
입력받은 세개의 수 중에서 10보다 큰 수를 찾은 다음
def get_numbers_more_10(number_list):
return [number for number in number_list if number >= 10]
10보다 큰 수의 개수가
- 0개 일때 zilch
- 1개 일때 double
- 2개 일때 double-double
- 3개 일때 triple-double
를 출력하는 문제입니다.
answer_dict = {
0: "zilch", 1: "double", 2: "double-double", 3: "triple-double"
}
각 개수마다 출력할 문자열을 dictionary로 만들어 두었습니다.
answer_string_list = []
more_10_num = get_numbers_more_10(
number_list=number_list
)
more_10_num_len = len(more_10_num)
answer = answer_dict[more_10_num_len]
number_list = list(map(str, number_list))
answer_string = f"{' '.join(number_list)}\n{answer}"
answer_string_list.append(answer_string)
정답 : "\n\n".join(answer_string_list)
10 보다 큰 수를 구하고 그 개수로 출력할 문자열을 dictionary 에서 꺼낸 다음
more_10_num = get_numbers_more_10(
number_list=number_list
)
more_10_num_len = len(more_10_num)
answer = answer_dict[more_10_num_len]
입력받은 숫자와 출력할 문자열을 정답형식으로 만들어서 리스트에 넣어둔 다음
number_list = list(map(str, number_list))
answer_string = f"{' '.join(number_list)}\n{answer}"
개행문자 2개로 join하고 출력합니다.
정답 : "\n\n".join(answer_string_list)
전체 코드는 아래를 참고해주세요.
👨🏻💻 코드 ( Solution )
def get_numbers_more_10(number_list):
return [number for number in number_list if number >= 10]
def majestic_10(number_lists):
answer_string_list = []
for number_list in number_lists:
answer_dict = {
0: "zilch", 1: "double", 2: "double-double", 3: "triple-double"
}
more_10_num = get_numbers_more_10(
number_list=number_list
)
more_10_num_len = len(more_10_num)
answer = answer_dict[more_10_num_len]
number_list = list(map(str, number_list))
answer_string = f"{' '.join(number_list)}\n{answer}"
answer_string_list.append(answer_string)
return "\n\n".join(answer_string_list)
if __name__ == "__main__":
number_lists = []
for _ in range(int(input())):
number_list = list(map(int, input().split()))
number_lists.append(number_list)
print(majestic_10(number_lists=number_lists))
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaekJoon] 6438번 : Reverse Text (Python) (0) | 2022.10.31 |
---|---|
[BaekJoon] 24745번 : Morse Code Palindromes (Python) (0) | 2022.10.30 |
[BaekJoon] 25858번 : Divide the Cash (Python) (0) | 2022.10.28 |
[BaekJoon] 6810번 : ISBN (Python) (0) | 2022.10.27 |
[Programmers] 숫자 짝궁 (Python) (0) | 2022.10.26 |
Comments