[BOJ / C++] 배열 합치기 (정렬)

2025. 7. 16. 23:33·코딩테스트/BOJ

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

 

1. 코드

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

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

    int n, m;
    cin >> n >> m;

    vector<int> a(n);
    vector<int> b(m);
    for (int i = 0; i < n; i++) {
        cin >> a[i];
    }
    for (int i = 0; i < m; i++) {
        cin >> b[i];
    }

    vector<int> mergeList(n+m);
    
    int aidx = 0, bidx = 0;
    for (int i = 0; i < n+m; i++) {
        if (aidx == n) mergeList[i] = b[bidx++];
        else if (bidx == m) mergeList[i] = a[aidx++];
        else if (a[aidx] <= b[bidx]) mergeList[i] = a[aidx++];
        else mergeList[i] = b[bidx++];
    }

    for (int i: mergeList) {
        cout << i << ' ';
    }
}

 

 

2. 분석

aidx == n, bidx == m에 대한 처리가 중요하다. 3번째, 4번째 조건 처리만 있어도 되지 않나 생각할 수 있지만, aidx, bidx 인덱스를 증가시켜놓기 때문에 a[aidx], b[bidx]를 참조하는 순간 OOB 에러가 발생할 수 있다.

 

3. 시간복잡도

n+m번의 비교가 일어나므로 O(n+m)에 동작한다. 시간제한이 1초이고 n, m < 1,000,000이므로 2 * 10^6 < 10^8 이므로 시간내 통과가 가능하다.

 

 

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

[BOJ / C++] 카드 (정렬)  (0) 2025.07.18
[BOJ / C++] 시리얼 번호 (정렬)  (0) 2025.07.18
[BOJ / C++] 재귀함수가 뭔가요? (재귀)  (0) 2025.07.15
[BOJ / C++] 벽 부수고 이동하기 (BFS로 풀이, 완전탐색 X)  (0) 2025.07.15
[BOJ / C++] 부분수열의 합 (백트래킹)  (0) 2025.07.14
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 카드 (정렬)
  • [BOJ / C++] 시리얼 번호 (정렬)
  • [BOJ / C++] 재귀함수가 뭔가요? (재귀)
  • [BOJ / C++] 벽 부수고 이동하기 (BFS로 풀이, 완전탐색 X)
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 / C++] 배열 합치기 (정렬)
상단으로

티스토리툴바