본문 바로가기
코딩테스트/코딩테스트 문제

코딩테스트 준비 - 백준1181번 단어 정렬 풀이: 파이썬 문자열 정렬(파이썬)

by 공부가싫다가도좋아 2021. 6. 5.
반응형

백준 1181번 풀이


문제풀러가기

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

 

1181번: 단어 정렬

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

www.acmicpc.net


문제


풀이

1. 문자열 길이가 가장 작은 순으로 정렬

len(string) 사용

 

2. 문자열 길이가 같을 시, 사전순으로 정렬

문자열 비교 사용: string1>string2

 

3. 리스트 중복제거 사용

arr_list = list(set(arr_list))


코드

import sys

N = int(sys.stdin.readline())
arr = []
arr_seq = []

for i in range (N):
  arr.append(str(sys.stdin.readline()))

arr = list(set(arr)) #중복 제거
arr.sort() #알파벳 우선순으로 정렬

for i in range(len(arr)):
  arr_seq.append([len(arr[i]), i])  
  #길이 정렬부터 하기 위해 문자열의 길이와, 
  # arr리스트안에서의 문자열 인덱스를 arr_seq 리스트에 추가

arr_seq.sort() #길이 우선순으로 정렬

for i in range(len(arr_seq)):
  str_index = arr_seq[i][1] #문자열이 arr리스트에서의 인덱스
  print(arr[str_index],end="") #end=""으로 개행문자 제거

코드 풀이

1. 우선 문자열을 arr리스트에 담습니다.

 

2. arr리스트에서 set을 통해 중복 제거를 해줍니다.

 

3. 사전순으로 정렬해야 하므로 arr.sort를 통해 정렬을 해줍니다. 

* arr.sort를 안해줄 시 마지막 출력에 사전순으로 정렬이 안됩니다.

 

4. 또다른 리스트 arr_seq에는 arr리스트에 담겨있는 문자열들의 길이와 인덱스를 담아 넣습니다 => (len(arr[i]), i)

 

5. arr_seq.sort를 해줄 시, len(arr[i])를 우선순으로 정렬합니다. 

 

6. arr_seq리스트에는 문자열의 길이가 작은 순부터 정렬 되어 있으며,3번에서

이미 사전순 정렬을 해줬기 때문에 arr_seq[i][1]대로 출력해주면 된다.

*arr_seq[i][1]은 문자열의 arr에서의 인덱스, 4번 참고

 

7. sys.stdin.readline에서 문자열을 출력할  경우 개행문자가 같이 출력되니 end=""으로 개행문자를 지워준다. 

*혹은 처음부분에서 arr.append(str(sys.stdin.readline().strip()))을 쓰면 된다.

*int(sys.stdin.readline()) 같이 int형일 경우는 개행문자 출력 안됨.


도움이 되셨다면 하트 꾹 눌러주세요 :)

반응형

댓글