동전 교환 문제 연산 줄일 때,
235
작성한 질문수 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
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





