백준(Java)/23년 4월
[Java] 백준 - 18870번: 좌표 압축
C0MPAS
2023. 4. 4. 14:48
4월 4일(화) - 정렬 (18870번)
18870번: 좌표 압축
수직선 위에 N개의 좌표 X1, X2, ..., XN이 있다. 이 좌표에 좌표 압축을 적용하려고 한다. Xi를 좌표 압축한 결과 X'i의 값은 Xi > Xj를 만족하는 서로 다른 좌표의 개수와 같아야 한다. X1, X2, ..., XN에 좌
www.acmicpc.net
ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ
문제점
ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ
풀이
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
import java.util.StringTokenizer;
import java.util.Arrays;
import java.util.HashMap;
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());
int[] origin = new int[N];
int[] sorted = new int[N];
HashMap<Integer, Integer> rankingMap = new HashMap<>();
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
for(int i=0; i<N; i++)
{
sorted[i] = origin[i] = Integer.parseInt(st.nextToken());
}
Arrays.sort(sorted);
int rank=0;
for(int v : sorted)
{
if(!rankingMap.containsKey(v))
{
rankingMap.put(v,rank);
rank++;
}
}
StringBuilder sb = new StringBuilder();
for(int key : origin)
{
int ranking = rankingMap.get(key);
sb.append(ranking).append(' ');
}
System.out.println(sb);
}
}
ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ
풀이출처 -> https://st-lab.tistory.com/279