[BOJ / C++] 보물 (그리디)

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

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

 

1. 코드

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

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

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

    sort(a.begin(), a.end());
    sort(b.begin(), b.end(), [](int a, int b) {return a > b;});

    int s = 0;
    for (int i = 0; i < n; i++) {
        s += a[i] * b[i];
    }
    cout << s;
}

 

 

2. 분석

가장 큰 것과 가장 작은 것을 곱해서 더하면 최소가 되고, 가장 큰 것과 가장 큰 것을 곱해서 더하면 최대가 된다. 따라서 하나는 오름차순으로 하나는 내림차순으로 정렬해서 곱해서 더하면 끝난다.

 

3. 시간복잡도

정렬에 시간복잡도가 가장 크게 걸린다. O(nlgn)이고 n = 50 이므로 nlgn = 300 < 10^8 이므로 시간제한 2초 내에 통과 가능하다.

 

 

 

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

[BOJ / C++] 피보나치 함수 (다이나믹 프로그래밍)  (0) 2025.07.25
[BOJ / C++] Puyo Puyo (시뮬레이션, BFS)  (0) 2025.07.25
[BOJ / C++] 로프 (그리디)  (0) 2025.07.23
[BOJ / C++] 빙산 (BFS)  (0) 2025.07.23
[BOJ / C++] 동전 0 (그리디)  (0) 2025.07.22
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 피보나치 함수 (다이나믹 프로그래밍)
  • [BOJ / C++] Puyo Puyo (시뮬레이션, BFS)
  • [BOJ / C++] 로프 (그리디)
  • [BOJ / C++] 빙산 (BFS)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (175) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (18) N
        • Java (8)
        • Spring (4)
        • Docker (4)
        • AI Agent (2) N
      • 코딩테스트 (96)
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13)
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

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

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 보물 (그리디)
상단으로

티스토리툴바