공부하기/백준

[Python] 백준 풀기 1431 - 시리얼 번호

XEV 2023. 1. 1. 21:55

파이썬 백준 1431번

실버 3

https://www.acmicpc.net/problem/1431

 

1431번: 시리얼 번호

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

www.acmicpc.net

 

 

 

 

 

문제 보기

분류: 정렬

 

 

 

 

 

문제 풀기

가장 바깥 리스트를 시리얼 번호 최대 길이인 50+1 로 지정하고 기타의 시리얼 번호를 입력받을 때마다 각 index 에 맞게 누적하여 저장한다. 저장하기 전에 함수 fnSumOfNum(serial) 에 넣어 숫자만 판별하여 그 수를 모두 더하고 sNum_serial 에 첫 번째에 그 합을 두 번째에 시리얼 번호를 모은다.

    예제 입력 1)

        # [[], [[0, 'A']], [], [], [[0, 'ABCD'], [10, '145C'], [10, 'A910'], [6, 'Z321']], ,,,]

 

함수 fnSortAndPrint(serialLen_ls) 를 사용하여 모두 저장된 리스트에서 빈 공간을 제외하고 순차적으로 뽑아내면서 그 안의 원소를 lambda 로 정렬 후 답을 출력한다.

        serialLen_ls[i].sort(key = lambda x : (x[0], x[1]))

    예제 입력 1)

        # [[0, 'A']]
        # A
        # [[0, 'ABCD'], [6, 'Z321'], [10, '145C'], [10, 'A910']]
        # ABCD
        # Z321
        # 145C
        # A910

 

 

 

 

 

코드 보기

import sys
inputdata = sys.stdin.readline


def fnSumOfNum(serial):
    sNum = 0
    sNum_serial = []
    for s in serial:
        if s.isdigit():
            sNum += int(s)
    sNum_serial.append(sNum)
    sNum_serial.append(serial)
    return sNum_serial
    

def fnSortAndPrint(serialLen_ls):
    for i in range(len(serialLen_ls)):
        if len(serialLen_ls[i]) != 0:
            serialLen_ls[i].sort(key = lambda x : (x[0], x[1]))
            # print(serialLen_ls[i])          # TEST PRINT
            
            for j in range(len(serialLen_ls[i])):
                print(serialLen_ls[i][j][1])


if __name__ == "__main__":
    n = int(inputdata().strip())
    
    serialLen_ls = [[] for _ in range(51)]
    # print(serialLen_ls)                     # TEST PRINT
    for _ in range(n):
        serial = str(inputdata().strip())
        serialLen = len(serial)
        sNum_serial = fnSumOfNum(serial)
        serialLen_ls[serialLen].append(sNum_serial)
    # print(serialLen_ls)                     # TEST PRINT
    fnSortAndPrint(serialLen_ls)

 

 

 

 

 

추가 하기

예제 입력 1번 (최대 시리얼 번호의 길이를 4로 제한, 가독성 있는 출력 결과를 확인하기 위해)

import sys
inputdata = sys.stdin.readline


def fnSumOfNum(serial):
    sNum = 0
    sNum_serial = []
    for s in serial:
        if s.isdigit():
            sNum += int(s)
    sNum_serial.append(sNum)
    sNum_serial.append(serial)
    return sNum_serial
    

def fnSortAndPrint(serialLen_ls):
    for i in range(len(serialLen_ls)):
        if len(serialLen_ls[i]) != 0:
            serialLen_ls[i].sort(key = lambda x : (x[0], x[1]))
            print(serialLen_ls[i])          # TEST PRINT
            
            for j in range(len(serialLen_ls[i])):
                print(serialLen_ls[i][j][1])


if __name__ == "__main__":
    n = int(inputdata().strip())
    
    serialLen_ls = [[] for _ in range(5)]
    print(serialLen_ls)                     # TEST PRINT
    for _ in range(n):
        serial = str(inputdata().strip())
        serialLen = len(serial)
        sNum_serial = fnSumOfNum(serial)
        serialLen_ls[serialLen].append(sNum_serial)
    print(serialLen_ls)                     # TEST PRINT
    fnSortAndPrint(serialLen_ls)



# 5
# ABCD
# 145C
# A
# A910
# Z321

# [[], [], [], [], []]
# [[], [[0, 'A']], [], [], [[0, 'ABCD'], [10, '145C'], [10, 'A910'], [6, 'Z321']]]

# [[0, 'A']]
# A
# [[0, 'ABCD'], [6, 'Z321'], [10, '145C'], [10, 'A910']]
# ABCD
# Z321
# 145C
# A910