Оптимизация повторения тяжелых операций в 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; }
enru