JavaScript에서 무거운 연산 반복 최적화하기
이전 강의에서 함수 반복 호출은 실제로 매우 적은 시간만 소요되며 우리의 최적화는 그다지 많은 것을 절약하지 못했습니다. 그러나, 상당히 오랜 시간이 걸리는 "무거운" 함수를 여러 번 호출해야 한다면 상황은 훨씬 나빠질 것입니다.
예를 들어, 숫자의 약수를 찾는 함수가 있다고 가정해 봅시다:
function getDivisorsSum(num) {
let res = 0;
for (let i = 1; i <= num; i++) {
if (num % i === 0) {
res += i;
}
}
return res;
}
분명히, 이 함수는 상당히 "무겁습니다". 따라서 다음과 같은 코드를 작성하는 것은 나쁜 생각입니다:
let num = 123456;
if (getDivisorsSum(num) >= 10 && getDivisorsSum(num) <= 100) {
console.log('+++');
} else {
console.log('---');
}
물론, "무거운" 연산을 한 번 수행하고 그 결과를 변수에 저장한 다음, 필요한 곳에서 이 변수를 사용하는 것이 더 좋습니다:
let num = 123456;
let sum = getDivisorsSum(num);
if (sum >= 10 && sum <= 100) {
console.log('+++');
} else {
console.log('---');
}
아래 코드를 최적화하세요:
let num = 1233456789;
if (getSumSquare(num) >= 10 && getSumSquare(num) <= 100) {
console.log('+++');
} else {
console.log('---');
}
function getSumSquare(num) {
let digits = String(num).split('');
let sum = 0;
for (let digit of digits) {
sum += digit ** 2;
}
return sum;
}