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
- ubuntu
- PYTHON
- leetcode
- 편스토랑
- Real or Not? NLP with Disaster Tweets
- 캐치카페
- 맥북
- 자연어처리
- dacon
- Baekjoon
- Kaggle
- 백준
- 금융문자분석경진대회
- 코로나19
- Git
- 프로그래머스
- 더현대서울 맛집
- Docker
- AI 경진대회
- 파이썬
- programmers
- github
- SW Expert Academy
- ChatGPT
- 우분투
- hackerrank
- 데이콘
- gs25
- 편스토랑 우승상품
- 프로그래머스 파이썬
Archives
- Today
- Total
솜씨좋은장씨
[BaeKJoon] 11652번: 카드 (Python) 본문
728x90
반응형
1일 1문제 9일차!
오늘의 문제는 카드입니다.
이 문제는 -26^2와 26^2 사이의 N개의 카드의 숫자를 입력받으면
그 중 가장 많이 존재하는 카드의 숫자는 무엇인지 찾아내는 문제입니다.
저번 수 정렬하기 3에서 dictionary를 활용하여 풀었던 것을 활용해보려합니다.
import sys
N = int(input())
my_dict = {}
for i in range(N):
num = int(sys.stdin.readline())
if num not in my_dict.keys():
my_dict[num] = 1
else:
my_dict[num] = my_dict[num] + 1
new_dict = dict([(value, key) for key, value in my_dict.items()])
print(new_dict[max(new_dict.keys())])
결과는!
왜 틀렸나하고 문제를 잘 살펴보니
여러개의 숫자가 있을 경우 그 중에서 가장 작은 수를 출력해야하는 조건을 만족하지 못한 답이었습니다.
그리고 key와 value를 바꿔주는 과정에서도 같은 value값의 수가 key로 바뀌면서
가장 작은 수를 추출할 수 없게 사라지는 경우도 있었습니다.
이번에는 dictionary의 values() 함수를 활용해 풀어보기로 했습니다.
import sys
N = int(input())
my_dict = {}
for i in range(N):
num = int(sys.stdin.readline())
if num not in my_dict.keys():
my_dict[num] = 1
else:
my_dict[num] = my_dict[num] + 1
max_num = max(list(my_dict.values()))
answer = []
for key, value in my_dict.items():
if value == max_num:
answer.append(key)
print(min(answer))
결과는!
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaeKJoon] 1377번: 버블 소트 (Python) (0) | 2020.02.17 |
---|---|
[BaeKJoon] 11004번: K번째 수 (Python) (0) | 2020.02.16 |
[BaeKJoon] 10989번: 수정렬하기 3 (Python) (6) | 2020.02.14 |
[BaeKJoon] 10825번: 국영수 (Python) (0) | 2020.02.13 |
[BaeKJoon] 10814번: 나이순 정렬 (Python) (0) | 2020.02.12 |
Comments