코딩일지/python 백준 알고리즘

python 백준 알고리즘 1181번: 단어 정렬

야언 2022. 9. 20. 19:17

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

 

1181번: 단어 정렬

첫째 줄에 단어의 개수 N이 주어진다. (1 ≤ N ≤ 20,000) 둘째 줄부터 N개의 줄에 걸쳐 알파벳 소문자로 이루어진 단어가 한 줄에 하나씩 주어진다. 주어지는 문자열의 길이는 50을 넘지 않는다.

www.acmicpc.net

중복 제거 - set 자료형 / if (변수) not in:

문자열을 길이순으로 정렬 - sort(key = len)

두 가지만 신경써주면 계속 쓰던거 쓰는 문제.

 

내 제출

import sys

n = int(sys.stdin.readline())
set_list = set()  # 중복제거

for i in range(n):
    set_list.add(sys.stdin.readline().strip())  # strip() 줄바꿈 대응

text_list = list(set_list)
text_list.sort()
text_list.sort(key = len)  # 문자열 길이순으로 정렬

for i in text_list:
    print(i)