티스토리 뷰

PS

프로그래머스. 최솟값 만들기

tose33 2021. 11. 9. 21:07

https://programmers.co.kr/learn/courses/30/lessons/12941

 

코딩테스트 연습 - 최솟값 만들기

길이가 같은 배열 A, B 두개가 있습니다. 각 배열은 자연수로 이루어져 있습니다. 배열 A, B에서 각각 한 개의 숫자를 뽑아 두 수를 곱합니다. 이러한 과정을 배열의 길이만큼 반복하며, 두 수를 곱

programmers.co.kr

 

n이 1000까지여서 처음에 그냥 브루트포스로 풀었다

next_permutation 함수를 중첩된 형태로 풀었는데 next_permutation 함수가 O(n)이므로 될줄알았다.

그런데 생각해보니 각 수들을 곱하는 과정에서 또 n의 반복문이 필요하므로 O(n^3)이 되버려서 실패.

 

그냥 얌전히 그리디로 풀기로 했다.

큰 숫자가 작은 숫자와 곱해져야 작은 수가 나올것이므로 두 개의 벡터를 각각 오름차순, 내림차순 정렬 후 곱한다.

 

댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2026/02   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
글 보관함