인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

42님의 프로필 이미지
42

작성한 질문수

자바스크립트 알고리즘 문제풀이 입문(코딩테스트 대비)

9. 동전교환(DFS-Cut Edge Tech)

동전 교환 문제 연산 줄일 때,

작성

·

210

1

안녕하세요 선생님 강의 너무 잘 듣고 있습니다.

다름이 아니라 9.동전교환(DFS-Cut Edge Tech) 문제에 대해서 궁금한 점이 있어서 질문 올립니다.

강의 마지막 부분에서,

if(L>answer) return;

코드를 추가하여 불필요한 연산을 차단할 수 있다고 말씀해주셨는데,

동전의 최소 개수를 구하는 문제이니 만약 arr배열을 내림차순으로 미리 정렬하면 큰 단위의 동전부터 거슬러주게 되니 연산을 훨씬 더 줄일 수 있는 게 아닌가 하는 생각이 들었습니다. 이 문제의 경우도 5원짜리 3개인 경우가 바로 나오니 딱 한 번의 경우로 답을 구하여 연산이 더 빨라질 수 있지 않나요?

            function solution(M, arr){

                let answer=Number.MAX_SAFE_INTEGER;

                arr.sort((a,b)=>b-a);

                function DFS(L, sum){

                    if(sum>M) return;

                    if(L>answer) return;

                    if(sum===M){

                        console.log(L, sum);

                        answer=Math.min(answer, L);

                    } else {

                        for(let i=0; i<arr.length; i++){

                            DFS(L+1, sum+arr[i]);

                        }

                    }

                }

                DFS(0, 0);

                return answer;

            }

다만 궁금한 것은,

arr.sort((a,b)=>b-a); 를 추가했을 때 sort 함수를 사용하면 선생님이 하신 방법보다 연산 시간이 더 오래 걸리는지가 궁금합니다.

횟수로는 확실히 줄어드는 것 같아서요.

감사합니다.

답변 1

1

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

정렬하는데 시간이 조금 들더라도 동전단위를 내림차순으로 정렬해서 DFS를 돌리는게 이 문제는 훨씬 효율성이 높습니다. 

42님의 프로필 이미지
42

작성한 질문수

질문하기