[BOJ 10989 / C++] 수 정렬하기 3 (정렬)

2025. 8. 10. 00:42·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/10989

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

int main() {
    ios::sync_with_stdio(0); cin.tie(0);
    
    int n;
    cin >> n;
    
    int num;
    int arr[10001];
    fill(arr, arr+10001, 0);

    for (int i = 0; i < n; i++) {
        cin >> num;
        arr[num]++;
    }
    
    for (int i = 1; i <= 10000; i++) {
        while (arr[i]) {
            cout << i << '\n';
            arr[i]--;
        }
    }
}

 

 

2. 시간복잡도

그냥 vector를 사용해서 sort로 끝내면 메모리 초과가 발생한다. 메모리 제한이 8MB로 굉장히 짠 것을 알 수 있다. 수의 갯수가 10^7이고 int로 하면 4byte * 10^7이므로 40MB로 초과가 된다.

 

수의 크기가 작으니까 short를 쓸까? short는 2byte이므로 20MB로 여전히 시간초과이다. 이 문제는 수의 범위가 10^4 이하인 자연수라는 점에 초점을 맞춰야한다. 배열을 크게 잡고 갯수를 세는 Counting Sort로 구현하면 된다.

 

Counting Sort의 시간복잡도는 O(n)이므로 5초 시간제한은 무리가 없다. 배열도 int로 선언시 4byte * 10^4 < 1MB 이므로 메모리도 충분하다.

 

 

3. 분석

메모리 초과를 인지하고 Counting Sort로 관점을 바꾸는 것이 핵심이다.

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ 4803 / C++] 트리 (트리)  (0) 2025.08.12
[BOJ 2606 / C++] 바이러스 (그래프)  (0) 2025.08.12
[BOJ 13975 / C++] 파일 합치기 3 (우선순위 큐)  (0) 2025.08.06
[BOJ 14891 / C++] 톱니바퀴 (시뮬레이션)  (0) 2025.08.04
[BOJ / C++] 홍익 투어리스트 (이진검색트리)  (0) 2025.08.03
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ 4803 / C++] 트리 (트리)
  • [BOJ 2606 / C++] 바이러스 (그래프)
  • [BOJ 13975 / C++] 파일 합치기 3 (우선순위 큐)
  • [BOJ 14891 / C++] 톱니바퀴 (시뮬레이션)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (173) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (16)
        • Java (8)
        • Spring (4)
        • Docker (4)
        • AI Agent (0)
      • 코딩테스트 (96) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ 10989 / C++] 수 정렬하기 3 (정렬)
상단으로

티스토리툴바