dictionary형태로, key값에 따른 value값을 업데이트함으로써 최대 value를 가지는 key값을 추출하는 코드이다.
일단 주의해야 할 것은 print(dict[3])이런식으로 하면 key값이 아닌 value값이 나온다는 사실!
그래서 애초에 dict의 key값들을 .keys()로 모아둔 다음에 출력하는 편이 낫다.
코드를 자세히 설명하자면 동아리의 key값을 각각의 이름으로 지정하고 모두 0으로 초기화시킨다.
이후 n으로 동아리원을 입력받고
가장 최대로 문제를 푼 사람을 대표로 내세우기 때문에 L보다 큰 값이 나올 때마다 값을 다시 갱신시켜준다.
☆이후 '가장 큰 value값을 가지는 key를 가지고 오는 함수는 max_key = max(딕셔너리 이름, key=딕셔너리이름.get)으로 구현할 수 있다.
그다음에는 우리가 print(max_key)하면 숫자로 나오기 때문에 .keys 리스트에 있는 max_key번째 항목을 꺼내면 된다.
DONG = {"PROBRAIN":0, "GROW":0,"ARGOS":0, "ADMIN":0,"ANT":0,"MOTION":0,"SPG":0,"COMON":0,"ALMIGHTY":0}
n=int(input())
for i in range(9):
L=0
S=list(map(int, input().split()))
for j in S:
if j>L:
L=j
if L>=0:
DONG[i]=L
max_key = max(DONG, key=DONG.get)
print(list(DONG.keys())[max_key])
'Koala - 5기 > 기초 알고리즘 스터디' 카테고리의 다른 글
[백준/python] 2495. 연속구간 (2) | 2022.01.19 |
---|---|
[백준/C++] 9012번 괄호 (1) | 2022.01.18 |
[백준/python] 11931 수정렬하기-4 (0) | 2022.01.17 |
[백준/python] 10824번 네 수 (2) | 2022.01.17 |
[백준/python] - 10886번: 0 = not cute / 1 = cute (0) | 2022.01.16 |