[BOJ / C++] 숫자 카드 2 (이분탐색)

2025. 7. 26. 21:18·코딩테스트/BOJ

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

 

> 방법 1. 직접 구현 

1-1. 코드

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

int lower_idx(vector<int>& arr, int target, int len) {
    int st = 0;
    int en = len;
    while (st < en) {
        int mid = (st + en) / 2;
        if (arr[mid] >= target) en = mid;
        else st = mid + 1;
    }
    return st;
}

int upper_idx(vector<int>& arr, int target, int len) {
    int st = 0;
    int en = len;
    while (st < en) {
        int mid = (st + en) / 2;
        if (arr[mid] > target) en = mid;
        else st = mid + 1;
    }
    return st;
}

int main() {
    ios::sync_with_stdio(0); cin.tie(0);

    int n;
    cin >> n;
    
    vector<int> arr(n);
    for (int i = 0; i < n; i++) {
        cin >> arr[i];
    }
    sort(arr.begin(), arr.end());

    int m;
    cin >> m;
    while (m--) {
        int inp;
        cin >> inp;
        cout << upper_idx(arr, inp, n) - lower_idx(arr, inp, n) << ' ';
    }
}

 

 

1-2. 분석

upper_idx는 target이 들어갈 수 있는 가장 큰 인덱스를 의미하고, lower_idx는 target이 삽입될 수 있는 가장 작은 인덱스를 리턴한다. 각각은 이분탐색을 이용하므로 lgn의 시간복잡도를 갖는다. arr[mid] == target일 때 st를 움직일 지, en을 움직일지를 통해 가장 작은 인덱스 또는 가장 큰 인덱스를 리턴하게 되는 원리이다. 

해당 배열에서 upper_idx - lower_idx가 그 배열의 target 갯수를 나타내게 된다.

 

1-3. 시간복잡도

정렬에은 O(nlgn)이 걸리고, upper_idx, lower_idx에는 각각 O(lgn)이 소요된다.

 

 

> 방법 2. STL 사용 

2-1. 코드

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

int main() {
    ios::sync_with_stdio(0); cin.tie(0);

    int n;
    cin >> n;
    
    vector<int> arr(n);
    for (int i = 0; i < n; i++) {
        cin >> arr[i];
    }
    sort(arr.begin(), arr.end());

    int m;
    cin >> m;
    while (m--) {
        int inp;
        cin >> inp;
        cout << upper_bound(arr.begin(), arr.end(), inp) - lower_bound(arr.begin(), arr.end(), inp) << ' ';
    }
}

 

 

2-2. 분석

stl에 upper_bound(arr.begin(), arr.end(), target), lower_bound(arr.begin(), arr.end(), target)이 이미 구현되어있다. 각각은 vector일 때는 iterator 또는 배열인 경우 포인터를 반환한다. 해당 부분에 주의해서 stl을 잘 사용하면 된다. 마찬가지로 upper_bound - lower_bound가 target의 개수가 된다.

 

equal_range라는 lower_bound, upper_bound를 pair로 리턴해주는 stl도 있다.

 

2-3. 시간복잡도

정렬에은 O(nlgn)이 걸리고, upper_bound, lower_bound에는 각각 O(lgn)이 소요된다.

 

 

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

[BOJ / C++] 세 수의 합 (이분탐색)  (0) 2025.07.27
[BOJ / C++] 좌표 압축 (이분탐색)  (0) 2025.07.26
[BOJ / C++] 정수 삼각형 (다이나믹 프로그래밍)  (0) 2025.07.26
[BOJ / C++] 수 찾기 (이분탐색)  (0) 2025.07.25
[BOJ / C++] 피보나치 함수 (다이나믹 프로그래밍)  (0) 2025.07.25
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 세 수의 합 (이분탐색)
  • [BOJ / C++] 좌표 압축 (이분탐색)
  • [BOJ / C++] 정수 삼각형 (다이나믹 프로그래밍)
  • [BOJ / C++] 수 찾기 (이분탐색)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (174) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (17) N
        • Java (8)
        • Spring (4)
        • Docker (4)
        • AI Agent (1) N
      • 코딩테스트 (96)
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13)
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

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

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 숫자 카드 2 (이분탐색)
상단으로

티스토리툴바