import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
HashSet<String> words = new HashSet<>();
for (int i = 0; i < N; i++)
{
words.add(br.readLine());
}
List<String> words2 = new ArrayList<>(words);
Collections.sort(words2,(s1,s2) -> {
if (s1.length() == s2.length()){
return s1.compareTo(s2);
}
return s1.length() - s2.length();
});
for (String s : words2) {
System.out.println(s);
}
}
}
compareTo()라는 메서드를 이용하여 알파벳 순으로 정렬시킨 것과 list에 있는 Collection.sort(words2,(s1,s2) -> s1.length() - s2.length()); 와 같이 람다식을 배웠다. 람다식을 통해 문자열 길이의 비교를 할 수 있었다.