Otimização de repetição de operações pesadas em JavaScript
Na lição anterior, as chamadas repetidas de funções realmente levam muito pouco tempo e nossa otimização economizará não muito. No entanto, tudo ficará muito pior se fizermos várias chamadas a uma função "pesada" que leva um tempo considerável para ser executada.
Suponha, por exemplo, que temos uma função que encontra os divisores de um número:
function getDivisorsSum(num) {
let res = 0;
for (let i = 1; i <= num; i++) {
if (num % i === 0) {
res += i;
}
}
return res;
}
Obviamente, esta função é bastante "pesada". Portanto, seria uma má ideia escrever um código assim:
let num = 123456;
if (getDivisorsSum(num) >= 10 && getDivisorsSum(num) <= 100) {
console.log('+++');
} else {
console.log('---');
}
É melhor, claro, executar a operação "pesada" uma vez e armazenar o resultado em uma variável, e depois usar essa variável nos lugares necessários:
let num = 123456;
let sum = getDivisorsSum(num);
if (sum >= 10 && sum <= 100) {
console.log('+++');
} else {
console.log('---');
}
Otimize o código abaixo:
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;
}