시간초과를 관리하자

2022. 11. 17. 15:42·CS 이론/알고리즘
728x90

이번에 풀은 문제는 백준 18870번이다.

처음에 이 문제의 내용 자체를 몰라서 좌표압축이 뭔지부터 공부해보았다.

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

 

18870번: 좌표 압축

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

www.acmicpc.net

 

좌표압축이란 간단하게 설명하면 입력 받은 값들을 정렬하여서 순서대로 인덱스값(좌표를 부여하는 것이다.)

ex) 2,4,-10,4,-9를 주면 -10, -9, 2, 4, 4으로 정렬하고 -10은 0, -9는 1, 2는 2, 4는 3 그다음 4도 3으로한다.

 

그래서 코드를 짜면 해시맵을 사용해서 아래와 같은 코드를 짠다.

package backjoon;

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

public class b18870 {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int count  = Integer.parseInt(br.readLine());
        StringTokenizer st = new StringTokenizer(br.readLine());
        ArrayList<Integer> list = new ArrayList<>();
        for(int i=0; i<count; i++){
           list.add(Integer.parseInt(st.nextToken()));
        }

        ArrayList<Integer> sorted = new ArrayList<>();
        for(int i : list){
            sorted.add(i);
        }
        Collections.sort(sorted);
        HashMap<Integer,Integer> map =new HashMap();
        int tmp=0;
        for(int i=0; i<sorted.size(); i++){
            if(!map.containsKey(sorted.get(i))){
                map.put(sorted.get(i),tmp);
                tmp++;
            }
        }
        StringBuilder sb = new StringBuilder();
        for(int i : list){
            sb.append(map.get(i)+" ");
        }
        System.out.println(sb);
    }
}

 

처음에는 시간초과가 너무 나서 무엇이 문제 인지 몰랐었다. 내가 처음 짰던 코드는 

for(int i : list){
	System.out.print(map.get(i)+" ");
}

위와 같은 코드로 결과 값을 출력했었다.

나는 이 부분이 문제인지 몰랐었지만 학교선배가 알려줘서 알 수 있었다... System I/O를 하는 과정은 많은 시간을 잡아먹는다는 것을

그래서 도입 한 것이 StringBuilder이다. StringBuilber는 스트링값들을 모아서 한번에 출력하기 위한 String 클래스 객체를 만드는 것이다.

 

오늘은 한 감자 했다.

728x90

'CS 이론 > 알고리즘' 카테고리의 다른 글

2477번  (0) 2022.12.21
5430번  (1) 2022.12.20
1620번  (0) 2022.12.19
14425번  (1) 2022.12.19
2447번  (1) 2022.11.18
'CS 이론/알고리즘' 카테고리의 다른 글
  • 5430번
  • 1620번
  • 14425번
  • 2447번
Bello's
Bello's
개발하는 벨로
  • Bello's
    벨로의 개발일지
    Bello's
  • 전체
    오늘
    어제
    • 분류 전체보기 (199) N
      • 노예 일지 (7)
        • 스타트업 노예일지 (3)
      • CS 이론 (81)
        • 학과 수업 (4)
        • 알고리즘 (64)
        • 시스템 프로그래밍 (3)
        • 데이터 통신 (1)
        • 운영체제 (2)
        • 데이터베이스 (1)
      • project (3)
      • 나는 감자다. (4)
      • Spring (27)
      • 모각코 (45)
        • 절개와지조(모각코) (7)
        • 어쩌다보니 박준태가 조장이조 (11)
        • 어쩌다보니 박준태가 또 조장이조 (12)
      • LikeLion🦁 (20)
      • 캘리포니아 감자 (4)
      • OpenSource Contribute (1)
      • 우아한테크벨로 (1) N
        • 프리코스 회고록 (6)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    티스토리챌린지
    백준
    뛰슈
    그래프 순회
    타임리프
    누적합
    어렵다
    회고록
    나는 감자
    DFS
    프리코스
    오블완
    감자
    BFS
    JPA
    절개와지조
    Spring
    모각코
    자바
    8기
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.5
Bello's
시간초과를 관리하자
상단으로

티스토리툴바