-
[ 정렬 ] 두 배열의 원소 교체알고리즘/이코테 - 실전 2021. 8. 10. 16:32
난이도 : 하 풀이시간 : 20분 시간제한 : 2초
[ 정렬 ] 두 배열의 원소 교체
동빈이는 두 개의 배열 A와 B를 가지고 있다. 두 배열은 N개의 원소로 구성되어 있으며, 배열의 원소는
모두 자연수이다동빈이는 최대 K 번의 바꿔치기 연산을 수행할 수 있는데, 바꿔치기 연산이란 배열 A에 있는 원소 하나와
배열 B에 있는 원소 하나를 골라서 두 원소를 서로 바꾸는 것을 말한다동빈이의 최종 목표는 배열 A의 모든 원소의 합이 최대가 되도록 하는 것이며, 여러분은 동빈이를 도와야한다
N, K, 그리고 배열 A와 B의 정보가 주어졌을 때, 최대 K 번의 바꿔치기 연산을 수행하여 만들 수 있는
배열 A의 모든 원소의 합의 최댓값을 출력하는 프로그램을 작성하라예를 들어 N = 5, K = 3이고, 배열 A와 B가 다음과 같다고 해보자
- 배열 A = [1, 2, 5, 4, 3]
- 배열 B = [5, 5, 6, 6, 5]
이 경우, 다음과 같이 세 번의 연산을 수행할 수 있다 - 연산 1) 배열 A의 원소 '1'과 배열 B의 원소 '6'을 바꾸기
- 연산 2) 배열 A의 원소 '2'와 배열 B의 원소 '6'을 바꾸기
- 연산 3) 배열 A의 원소 '3'과 배열 B의 원소 '5'를 바꾸기
세 번의 연산 이후 배열 A와 배열 B의 상태는 다음과 같이 구성될 것이다 - 배열 A = [6, 6, 5, 4, 5]
- 배열 B = [3, 5, 1, 2, 5]
이때 배열 A의 모든 원소의 합은 26이 되며, 이보다 더 합을 크게 만들 수는 없다
:: 입력 조건
첫 번째 줄: N, K 가 공백으로 구분되어 입력 (1 <= N <= 100,000, 0 <= K <= N)
두 번째 줄: 배열 A의 원소들이 공백으로 구분되어 입력 (원소 a < 10,000,000인 자연수)
세 번째 줄: 배열 B의 원소들이 공백으로 구분되어 입력 (원소 b < 10,000,000인 자연수)
:: 출력 조건
최대 K번 바꿔치기 연산을 수행해서 가장 최대의 합을 갖는 A의 모든 원소 값의 합을 출력
내 코드
#include <iostream> #include <vector> #include <algorithm> #include <string> using namespace std; #define endl "\n" int main() { vector<int> a; vector<int> b; int n, k; cin >> n >> k; for (int i = 0; i < n; i++) { int num = 0; cin >> num; a.push_back(num); } for (int i = 0; i < n; i++) { int num = 0; cin >> num; b.push_back(num); } int res = 0; sort(a.begin(), a.end(), less<int>()); sort(b.begin(), b.end(), greater<int>()); for (int i = 0; i < k; i++) { if (a[i] < b[i]) { int tmp = a[i]; a[i] = b[i]; b[i] = tmp; } else if (a[i] >= b[i]) break; } for (int i = 0; i < n; i++) { res += a[i]; } cout << res << endl; return 0; }
정답 코드
#include <bits/stdc++.h> using namespace std; int n, k; vector<int> a, b; bool compare(int x, int y) { return x > y; } int main(void) { // N과 K를 입력받기 cin >> n >> k; // 배열 A의 모든 원소를 입력받기 for (int i = 0; i < n; i++) { int x; cin >> x; a.push_back(x); } // 배열 B의 모든 원소를 입력받기 for (int i = 0; i < n; i++) { int x; cin >> x; b.push_back(x); } // 배열 A는 오름차순 정렬 수행 sort(a.begin(), a.end()); // 배열 B는 내림차순 정렬 수행 sort(b.begin(), b.end(), compare); // 첫 번째 인덱스부터 확인하며, 두 배열의 원소를 최대 K번 비교 for (int i = 0; i < k; i++) { // A의 원소가 B의 원소보다 작은 경우 if (a[i] < b[i]) swap(a[i], b[i]); // 두 원소를 교체 // A의 원소가 B의 원소보다 크거나 같을 때, 반복문을 탈출 else break; } // 배열 A의 모든 원소의 합을 출력 long long result = 0; for (int i = 0; i < n; i++) { result += a[i]; } cout << result << '\n'; }
'알고리즘 > 이코테 - 실전' 카테고리의 다른 글
[ 이진탐색 ] 떡볶이 떡 만들기 (0) 2021.08.10 [ 이진탐색 ] 부품 찾기 (0) 2021.08.10 [ 정렬 ] 성적이 낮은 순서로 학생 출력하기 (0) 2021.08.10 [ 정렬 ] 위에서 아래로 (0) 2021.08.10 [ DFS | BFS ] 미로 탈출 (0) 2021.07.28