[BOJ] 1132 합 (Python)

2024. 2. 27. 18:31Algorithm

from collections import defaultdict
N = int(input())
d = defaultdict(int)
for i in range (0,12):
    d[chr(i + 65)] = 0 #각각의 인덱스 저장

cant_zero = []
for i in range (0,N):
    s = input() #입력되는 문자
    n = len(s)
    for j in range (0,n):
        if j == 0:
            cant_zero.append(s[j])
        d[s[j]] += 10 ** (n - 1 - j)

spell = []
for i in range (0,12):
    if d[chr(i + 65)] != 0:
        spell.append([chr(i+65) , d[chr(i + 65)]])
spell.sort(reverse = True, key = lambda x: x[1])
can_zero = []
revised = []

for i in range (0,len(spell)):
    if spell[i][0] in cant_zero:
        revised.append(spell[i])
    else:
        can_zero.append(spell[i])

if len(revised) <= 9:
    for i in range (0,len(can_zero)):
        revised.append(can_zero[i])
    if len(revised) <= 9:
        for j in range (0,9):
            revised.append([0,0])
            
revised = revised[0:9]
revised.sort(reverse= True, key = lambda x : x[1])

ans = 0
for i in range (0,9):
    ans += revised[i][1] * (9-i)
print(ans)

 

골드 3 문제였는데, 꽤 그래도 재밌게 풀은 느낌이 든다.

 

도중 몇가지 작업이 필요가 없을 수도 있었는데, 일단은 굉장히 빠르게 해결할 수 있었으니 ... 일단은 만족하는 것으로.

 

 

가장 중요한 아이디어 중 하나는, 0이 될 수 없는 문자들을 미리 분류해두고 우선순위에 둘 필요가 있는 것이다.

 

이 알고리즘에서는 알파뱃들을 총 2번에 걸쳐서 필터링을 하였다.

 

첫번째로, spell 리스트에서의 for문인데, 여기서 0이 될 수 없는 것들을 우선적으로 revised라는 리스트에 넣어줄 필요성이 있었다.

 

두번째로, if len(revised)에서, 길이를 강제로 9로 만들어주는 방법을 취하였다. 

 

꽤 재밌었던 문제 같았다.

'Algorithm' 카테고리의 다른 글

[BOJ] 백준 18111 마인크래프트 Python  (0) 2024.02.29
[BOJ] 2252 줄 세우기 Python  (0) 2024.02.28
[BOJ] 백준 14502 연구소 Python  (0) 2024.02.23
[BOJ] 1158 요세푸스 수열  (1) 2024.02.09
[BOJ] 28449 누가 이길까  (1) 2024.02.07