Algorithm/String

(Python) - BOJ(18870번) : 좌표 압축

하눤석 2022. 2. 16. 10:18
728x90

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


  • 문제 : 

수직선 위에 N개의 좌표 X1, X2, ..., XN이 있다. 이 좌표에 좌표 압축을 적용하려고 한다.

Xi를 좌표 압축한 결과 X'i의 값은 Xi > Xj를 만족하는 서로 다른 좌표의 개수와 같아야 한다.

X1, X2, ..., XN에 좌표 압축을 적용한 결과 X'1, X'2, ..., X'N를 출력해보자.

 

 

 


  • 풀이 :

다른 값들중 내 값보다 작은 값이 몇 개 존재하는지 찾는 문제이다. dictionary를 사용하면 쉽게 해결할 수 있다.

 

 

 


  • 소스코드 : 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import sys
input = sys.stdin.readline
 
if __name__ == "__main__":
    N = int(input())
    l = list(map(int,input().split()))
    L = sorted(l)
    D = dict()
    for i in l:
        D[i] = 0
    prev = L[0]
    for i in range(1,len(L)):
        if  L[i] != prev:
            D[L[i]] = D[prev]+1
        else:
            D[L[i]] = D[prev]
        prev = L[i]
    for i in l:
        print(D[i],end= ' ')
cs
320x100