반응형
문제(출처)
알파벳 소문자로 이루어진 N개의 단어가 들어오면 아래와 같은 조건에 따라 정렬하는 프로그램을 작성하시오.
1. 길이가 짧은 것부터
2. 길이가 같으면 사전 순으로
입력
첫째 줄에 단어의 개수 N이 주어진다. (1≤N≤20,000)
둘째 줄부터 N개의 줄에 걸쳐 알파벳 소문자로 이루어진 단어가 한 줄에 하나씩 주어진다.
주어지는 문자열의 길이는 50을 넘지 않는다.
출력
조건에 따라 정렬하여 단어들을 출력한다.
단, 같은 단어가 여러 번 입력된 경우에는 한 번씩만 출력한다.
예제 입력
13
but
i
wont
hesitate
no
more
no
more
it
cannot
wait
im
yours
예제 출력
i
im
it
no
but
more
wait
wont
yours
cannot
hesitate
내 풀이
import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.InputStreamReader;import java.io.OutputStreamWriter;import java.util.Arrays;import java.util.Comparator;import java.util.HashSet;
public class Main{ public static void main(String args[]) { String[] str = testCase1(); BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); HashSet<String> set = new HashSet<>(); for(int i = 0; i < str.length; i++) { set.add(str[i]); } String[] temp = new String[set.size()]; set.toArray(temp); Arrays.sort(temp, new Comparator<String>() {
@Override public int compare(String o1, String o2) { int length1 = o1.length(); int length2 = o2.length(); if(length1 == length2) { return o1.compareTo(o2); }else { return length1 - length2; } } }); for(int i=0; i < temp.length; i++) { System.out.println(temp[i]); } } public static String[] testCase1() { String[] str = { "but", "i", "wont", "hesitate", "no", "more", "no", "more", "it", "cannot", "wait", "im", "yours" };
return str; }}
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.Arrays;
import java.util.Comparator;
import java.util.HashSet;
public class Main{
public static void main(String args[]) {
String[] str = testCase1();
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
HashSet<String> set = new HashSet<>();
for(int i = 0; i < str.length; i++) {
set.add(str[i]);
}
String[] temp = new String[set.size()];
set.toArray(temp);
Arrays.sort(temp, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
int length1 = o1.length();
int length2 = o2.length();
if(length1 == length2) {
return o1.compareTo(o2);
}else {
return length1 - length2;
}
}
});
for(int i=0; i < temp.length; i++) {
System.out.println(temp[i]);
}
}
public static String[] testCase1() {
String[] str =
{ "but", "i", "wont", "hesitate", "no", "more", "no", "more", "it", "cannot", "wait", "im",
"yours" };
return str;
}
}
내 풀이 해석
해쉬셋으로 중복을 제거하고 배열에 담에 정렬 시 2가지 조건으로 정렬합니다.
아쉬운 점
해쉬맵을 정렬 하는 방법을 생각하느라 시간이 걸렸습니다.
아스키 코드로 변환하여 비교하고 정렬했는데 아스키 코드로 정렬 하려고 했던것 자체가 문제를 이해를 잘못했던거였습니다.
반응형
'개발(합니다) > 알고리즘&코테' 카테고리의 다른 글
알고리즘 단계별로 풀어보기 : BOJ-2581(소수) (0) | 2019.01.20 |
---|---|
알고리즘 단계별로 풀어보기 : BOJ-1978(소수구하기) (0) | 2019.01.19 |
알고리즘 단계별로 풀어보기 : BOJ-1427(소트인사이드) (0) | 2019.01.17 |
알고리즘 단계별로 풀어보기 : BOJ-2108(통계학) (0) | 2019.01.16 |
알고리즘 단계별로 풀어보기 : BOJ-10989(수정렬하기[3]) (0) | 2019.01.15 |