[JAVA] 백준 18870번 : 좌표 압축

2024. 1. 1. 19:16·Algorithm/Beakjoon
반응형

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

 

18870번: 좌표 압축

수직선 위에 N개의 좌표 X1, X2, ..., XN이 있다. 이 좌표에 좌표 압축을 적용하려고 한다. Xi를 좌표 압축한 결과 X'i의 값은 Xi > Xj를 만족하는 서로 다른 좌표 Xj의 개수와 같아야 한다. X1, X2, ..., XN에

www.acmicpc.net


import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
import java.util.stream.Collectors;

public class Main {
    static Map<Integer, Integer> map = new HashMap<>();
    static StringBuilder sb = new StringBuilder();
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int N = Integer.parseInt(br.readLine());
        int[] input = Arrays.stream(br.readLine().split(" ")).mapToInt(Integer::parseInt).toArray();
        List<Integer> sorted = new ArrayList<>();
        for (int n : input) {
            sorted.add(n);
        }
        Collections.sort(sorted);

        map.put(sorted.get(0), 0);
        int cnt = 1;
        for (int i = 1; i < sorted.size(); i++) {
            if (!map.containsKey(sorted.get(i))) {
                map.put(sorted.get(i), cnt);
                cnt++;
            }
        }
        for (int n : input) {
            sb.append(map.get(n)).append(" ");
        }
        System.out.print(sb);
    }
}

💡 정렬

풀이 

❗ 틀린 코드

더보기
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;

public class Main {
    static Map<Integer, Integer> map = new HashMap<>();
    static StringBuilder sb = new StringBuilder();
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int N = Integer.parseInt(br.readLine());
        int[] input = Arrays.stream(br.readLine().split(" ")).mapToInt(Integer::parseInt).toArray();
        List<Integer> sorted = new ArrayList<>();
        for (int n : input) {
            if(!sorted.contains(n))
                sorted.add(n);
        }
        Collections.sort(sorted);
        map.put(sorted.get(0), 0);
        int previous = sorted.get(0);
        for (int i = 1; i < sorted.size(); i++) {
            if (sorted.get(i) != previous) {
                map.put(sorted.get(i), i);
                previous = sorted.get(i);
            }
        }
        for (int n : input) {
            sb.append(map.get(n)).append(" ");
        }
        System.out.print(sb);
    }
}
  • 좌표 압축 = 해당 좌표보다 값이 작은 좌표들의 개수
  • 좌표 값 중복 가능함 →  동일한 좌표 값이 주어진 경우 동일한 압축 값으로 나와야 함
    • 입력값이 중복될 수 있음 →  중복 제거 해야 함

→  위 풀이는 시간 초과 

.. 카운팅 소트 사용 →  메모리 초과..ㅠ


최종

1. 좌표 입력 값을 받아온 후, 배열에 복사해 오름차순 정렬함

2. 정렬된 배열에서 새로운 수가 나올 때 마다 최근 순위에 +1한 것을 값으로 좌표 압축 실행

   - Map.containsKey()로 중복 제거

3. map 돌면서 좌표에 대응되는 압축 값 추가

💡 시간 제한 2초, 입력 크기가 10^6 이므로 시간 복잡도를 O(NlogN)으로 맞춰줘야 함 (O(n^2) 금지!)
   Collections.contains(e)는 시간 복잡도 O(n) 이므로 시간 복잡도가 O(N*N)이 됨
   ➡️ Map.containsKey(), get() 는 시간복잡도 O(1) 이므로 map을 사용해 시간 복잡도를 줄이자
➕ Collections.sort()의 시간복잡도는 O(NlogN) (평균/최악) 이므로 최종 시간 복잡도는 O(NlogN)이 됨
➕ Arrays.sort()의 시간복잡도는 O(N^2) (최악)이므로 차순위로...

 

반응형

'Algorithm > Beakjoon' 카테고리의 다른 글

[JAVA] 백준 11286번 : 절댓값 힙  (0) 2024.01.02
[JAVA] 백준 7569번 : 토마토  (0) 2024.01.02
[JAVA] 백준 10026번 : 적록색약  (1) 2024.01.01
[JAVA / 자바] 백준 7576번_토마토  (0) 2023.12.31
[JAVA / 자바] 백준 9095번_1, 2, 3 더하기  (0) 2023.12.30
'Algorithm/Beakjoon' 카테고리의 다른 글
  • [JAVA] 백준 11286번 : 절댓값 힙
  • [JAVA] 백준 7569번 : 토마토
  • [JAVA] 백준 10026번 : 적록색약
  • [JAVA / 자바] 백준 7576번_토마토
mopipi
mopipi
칠전팔기
공부하는 사람칠전팔기
mopipi
공부하는 사람
mopipi
전체
오늘
어제
  • 분류 전체보기 (162)
    • Java (4)
    • Spring (21)
      • Spring boot 입문 (16)
      • [dsc] Spring-Novice-Study (3)
    • SQL (5)
    • Algorithm (127)
      • Programmars (38)
      • Beakjoon (85)
    • Git (1)
    • 생각들 (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

hELLO· Designed By정상우.v4.5.2
mopipi
[JAVA] 백준 18870번 : 좌표 압축

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.