Notice
Recent Posts
Recent Comments
Link
«   2024/06   »
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30
Archives
Today
Total
관리 메뉴

UpDown Dev Story

[Java] 백준 1181 - 단어 정렬 본문

Algorithm

[Java] 백준 1181 - 단어 정렬

updown 2020. 4. 27. 10:57

N 개의 단어를 받아서

1. 길이가 짧은 것부터

2. 길이가 같으면 사전 순으로

정렬하여 출력하는 문제입니다.

하지만 문제를 자세히 읽어보면 중복된 단어의 경우 한번만 출력한다는 조건이 하나 더 있습니다.

그래서 입력받은 문자를 Set 자료구조에 담아서 중복을 제거한 뒤에 ArrayList로 옮겨서 정렬해주었습니다.

import java.util.*;

public class Main {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N = Integer.parseInt(sc.nextLine());

        // 중복 제거를 위해 set으로 먼저 input
        Set<String> set = new HashSet<>();

        for (int i = 0; i < N; i++){
            set.add(sc.nextLine());
        }

        // List 변환
        ArrayList<String> list = new ArrayList<>(set);

        // Comparator 클래스를 통하여 custom 정렬
        // 길이에 따라서 먼저 정렬하고 길이가 같으면 사전순으로 정렬
        Collections.sort(list, new Comparator<String>() {
            public int compare(String v1, String v2) {
                if(v1.length() > v2.length())
                    return 1;
                else if(v1.length() < v2.length())
                    return -1;
                else
                    return v1.compareTo(v2);
            }
        });

        for(String s : list)
            System.out.println(s);
    }
    }

'Algorithm' 카테고리의 다른 글

알고리즘 연습 - 문자 찾기  (0) 2021.05.20
[Java] 백준 3047 - ABC  (0) 2020.04.28
[Java] 백준 11650 - 좌표 정렬하기  (0) 2020.04.28
[Java] 백준 1026 - 보물  (0) 2020.04.27
[Java] 백준 10989 - 수 정렬하기 3  (0) 2020.04.27
Comments