백준 1181 : 단어 정렬 (sort의 key 옵션)
2023. 10. 17. 17:01ㆍ[알고리즘]/문제 풀이
문제
알파벳 소문자로 이루어진 N개의 단어가 들어오면 아래와 같은 조건에 따라 정렬하는 프로그램을 작성하시오.
- 길이가 짧은 것부터
- 길이가 같으면 사전 순으로
단, 중복된 단어는 하나만 남기고 제거해야 한다.
입력
첫째 줄에 단어의 개수 N이 주어진다. (1 ≤ N ≤ 20,000) 둘째 줄부터 N개의 줄에 걸쳐 알파벳 소문자로 이루어진 단어가 한 줄에 하나씩 주어진다. 주어지는 문자열의 길이는 50을 넘지 않는다.
출력
조건에 따라 정렬하여 단어들을 출력한다.
예제 입력 1 복사
13
but
i
wont
hesitate
no
more
no
more
it
cannot
wait
im
yours
예제 출력 1 복사
i
im
it
no
but
more
wait
wont
yours
cannot
hesitate
풀이
- set으로 중복값 삭제
- key로 조건을 달아주면 된다.(내림 차순시에는 -부호를 붙여주면 된다.)
ex)
array.sort(key = lambda x:x[0])
array.sort(key = lambda (x: x[1], -x[2]))
N = int(input())
words = set()
for _ in range(N):
words.add(input())
word_list = list(words)
#길이 순, 단어 순
word_list.sort(key=lambda x: (len(x), x))
for word in word_list:
print(word)
반응형
'[알고리즘] > 문제 풀이' 카테고리의 다른 글
백준 10815번 : 숫자 카드 (0) | 2023.10.18 |
---|---|
백준 18870번 : 좌표 압축 (1) | 2023.10.18 |
백준 11650번 : 좌표 정렬하기 (1) | 2023.10.16 |
프로그래머스 : 짝지어 제거하기 (1) | 2023.10.16 |
백준 5073번 : 삼각형과 세 변 (1) | 2023.10.16 |