연권
달콘박스
연권
전체 방문자
56,749
오늘
2
어제
102
  • 전체 (308)
    • Web (22)
      • JavaScript (8)
      • TypeScript (2)
      • Node.js (8)
      • HTML (0)
      • CSS (0)
      • Network (1)
      • Browser (0)
      • Patterns (3)
    • Framwork (4)
      • Vue.js (3)
      • Electron (1)
    • Infra&DevOps (1)
    • Algorithm (246)
    • Database (16)
    • Review (15)
    • Test (4)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

  • 소인수분해 알고리즘 [ javascript ]
    2021.09.08
    소인수분해 알고리즘 [ javascript ]
  • Vue.js에서 infinite scroll 구현하기
    2021.05.27
    Vue.js에서 infinite scroll 구현하기
  • 구름IDE 에서 MySQL 사용하기
    2020.01.09
    구름IDE 에서 MySQL 사용하기
  • JMeter로 REST API 자동 테스트 하기2
    2021.06.24
    JMeter로 REST API 자동 테스트 하기2
  • JMeter로 REST API 자동 테스트 하기1
    2021.06.22
    JMeter로 REST API 자동 테스트 하기1

태그

  • 문자열
  • 프로그래머스
  • 재귀
  • 백준ㅇ
  • 코딩테스트 연습
  • java
  • 백준
  • sql
  • 진법
  • MySQL
  • javascript
  • 동적계획법
  • 알고리즘
  • 진수
  • 스택
  • typescript
  • DP
  • 백트레킹
  • BFS
  • 정렬

최근 댓글

  • 포스팅 잘 보고 가요!
    아이폰 14 pro max
  • 감사합니다 수정하였습니다 :)
    연권
  • mysql.cnf 가 니라 mysqld.cnf 입니다.!!
    ㅇㅇ
  • 안녕하세요. 포스팅 감사합니다.. 저도 Vue-infin⋯
    지돌이
  • 안녕하세요 42서울 재웅시가 가능한가요?
    예나

최근 글

  • Observer Pattern
    2022.06.21
    Observer Pattern
  • Proxy Pattern (JavaScript)
    2022.06.07
    Proxy Pattern (JavaScript)
  • Singleton Pattern (JavaScript)
    2022.06.07
    Singleton Pattern (JavaScript)
  • 타입 좁히기 (Type Guard)
    2022.05.21
    타입 좁히기 (Type Guard)
  • 라인 플러스 면접 후기
    2022.05.13

티스토리

hELLO · Designed By 정상우.
연권

달콘박스

Algorithm

백준 18870번 좌표 압축 [ Java ]

2021. 4. 30. 16:10
반응형
 

18870번: 좌표 압축

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

www.acmicpc.net

값을 입력받은 후 입력 한 순서대로 출력 처리를 해야하기 때문에 sortedNum이라는 배열을 새로 만들어 주었습니다.

sum이라는 변수로 해당 숫자의 값을 할당 시켰고

마지막엔 hashmap에서 숫자를 탐색해서 숫자 키에 해당하는 값을 출력하였습니다.

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
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));
        StringBuilder sb = new StringBuilder();
        HashMap<Integer, Integer> hash = new HashMap<>();
        int N = Integer.parseInt(br.readLine());
        int[] num = Arrays.stream(br.readLine().split(" ")).mapToInt(Integer::parseInt).toArray();
        int[] sortedNum = Arrays.stream(num).sorted().toArray();
        int sum = 0;
        for (int i = 0; i < N; i++) {
            if (hash.containsKey(sortedNum[i]))
                continue;
            hash.put(sortedNum[i], sum++);
        }
        for (int i : num)
            sb.append(hash.get(i) + " ");
        System.out.print(sb);
    }
}

 

반응형
저작자표시 동일조건
  • 카카오스토리
  • 트위터
  • 페이스북

'Algorithm' 카테고리의 다른 글

백준 2225번 합분해 [ Java ]  (0) 2021.05.02
백준 1699번 제곱수의 합 [ Java ]  (0) 2021.05.01
백준 11659번 구간 합 구하기 4 [ Java ]  (0) 2021.04.30
백준 12852번 1로 만들기 2 [ Java ]  (0) 2021.04.30
프로그래머스 코딩테스트 연습 Level4 - 우유와 요거트가 담긴 장바구니 [ Mysql ]  (0) 2021.04.23
    'Algorithm' 카테고리의 다른 글
    • 백준 2225번 합분해 [ Java ]
    • 백준 1699번 제곱수의 합 [ Java ]
    • 백준 11659번 구간 합 구하기 4 [ Java ]
    • 백준 12852번 1로 만들기 2 [ Java ]
    백준, 알고리즘, 정렬
    연권
    연권
    댓글쓰기
    다음 글
    백준 1699번 제곱수의 합 [ Java ]
    이전 글
    백준 11659번 구간 합 구하기 4 [ Java ]

    티스토리툴바