CodingTest/Baekjoon

[baekjoon] 백준 1431번(파이썬): 시리얼 번호

JunJangE 2022. 4. 15. 02:18

문제

 

1431번: 시리얼 번호

첫째 줄에 기타의 개수 N이 주어진다. N은 50보다 작거나 같다. 둘째 줄부터 N개의 줄에 시리얼 번호가 하나씩 주어진다. 시리얼 번호의 길이는 최대 50이고, 알파벳 대문자 또는 숫자로만 이루어

www.acmicpc.net

알고리즘

- 정렬을 통해 문제를 수행한다.

- lambda를 통해 문자의 길이, 숫자의 합, 사전 순 <= 순으로 정렬한다.

- 정렬한 문자를 출력한다.

코드

import sys


# 숫자만 더한다.
def sum_num(num):
    res = 0
    for word in num:
        if word.isdigit():
            res += int(word)
    return res


n = int(sys.stdin.readline())
m = [list(sys.stdin.readline().strip()) for _ in range(n)]

# 정렬(길이, 숫자의 합, 사전순)
m.sort(key=lambda x: (len(x), sum_num(x), x))
for i in m:
    print("".join(i))

github

 

GitHub - junjange/CodingTest: 내가 푼 코딩 테스트 문제와 해결법

내가 푼 코딩 테스트 문제와 해결법. Contribute to junjange/CodingTest development by creating an account on GitHub.

github.com