728x90
반응형
🔗 문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/12941
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
👩💻 코드
#include <algorithm>
#include <vector>
using namespace std;
int solution(vector<int> A, vector<int> B){
int answer = 0;
sort(A.begin(), A.end());
sort(B.rbegin(), B.rend());
for(int i=0; i<A.size(); i++){
answer += A[i] * B[i];
}
return answer;
}
📝 풀이
두 수를 곱한 값을 누적하여 더한 값을 최솟값으로 만들기 위해서는 큰 수와 작은 수를 곱해야한다.
자연수 vector 하나는 오름차순, 다른 하나는 내림차순으로 정렬하여 같은 index 값을 곱한다.
곱한 값을 모두 더하여 답을 return 한다.
728x90
반응형
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 이진 변환 반복하기 (0) | 2024.07.13 |
---|---|
[프로그래머스] JadenCase 문자열 만들기 (0) | 2024.07.11 |
[프로그래머스] 올바른 괄호 (0) | 2024.07.10 |
[프로그래머스] 최댓값과 최솟값 (0) | 2024.07.10 |
[프로그래머스] 가장 많이 받은 선물 (0) | 2024.07.09 |