inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

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

235

42

작성한 질문수 1

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 함수를 사용하면 선생님이 하신 방법보다 연산 시간이 더 오래 걸리는지가 궁금합니다.

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

감사합니다.

javascript 코테 준비 같이 해요!

답변 1

1

김태원

안녕하세요^^

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

continue를 사용하는 이유

0

102

2

정렬 가능 여부 판단하기

0

81

2

알고리즘 학습법 관련해서 질문드립니다.

0

96

1

코드 리뷰 부탁드립니다!

0

107

1

indexOf를 사용해서 풀어보았습니다 !!

0

76

1

저는 이런식으로 구현 해보았습니다 !!

0

69

1

12,13,14 강의 소리만 나오고 검은 화면입니다

0

110

3

반복문 최소화하고 indexOf 사용해서 풀어봤습니다

0

74

1

영상 보기 전에 직접 풀어봤습니다.

0

79

1

섹션1의 17번문제 이 풀이로 풀어도 될까요?

0

143

2

정규표현식으로 처리해도 상관없나요 ?

0

127

2

3칸씩 건너뛸 수 있을 경우

0

133

2

강의에 대해 질문있습니다.

0

144

2

Object와 Set을 이용해 풀어봤습니다.

0

128

2

이렇게 해도 되나요?

0

107

2

선생님 중복 단어나 중복관련 문제들은 set을 이용하면 좋을것 같습니다.

0

149

2

이렇게 풀어도 괜찮을까요?

0

146

1

이렇게 풀어도 괜찮을까요?

0

125

1

모든 아나그램 찾기에서 시간복잡도

0

106

1

코드리뷰 부탁드립니다.

0

140

1

for loop 탈출은 return 문으로 해도 되지 않나요?

0

135

1

투포인트알고리즘으로 풀어봤습니다.

0

147

0

코드 리뷰 부탁드립니다.

0

121

1

코드 맞게 작성한 거 아닌가여??

0

150

1