Optimalizace cyklických operací v JavaScriptu
I lehká operace, která se mnohokrát opakuje v cyklu, může spotřebovat mnoho prostředků.
Podívejme se na příklad. Předpokládejme, že máme dané nějaké pole:
let arr = [1, 2, 3, 4, 5, 6];
Najděme průměr prvků tohoto pole. K tomu je potřeba najít součet prvků a vydělit jej jejich počtem. Předpokládejme, že nějaký programátor již tento úkol vyřešil následujícím způsobem:
let avg = 0;
for (let elem of arr) {
avg += elem / arr.length;
}
console.log(avg);
Podívejme se na problémy takového řešení. Technicky kód funguje správně a dává správný výsledek. Jde o to, že matematicky je korektní jak vydělit celý součet počtem, tak vydělit každý sčítaný prvek počtem.
Vzniká však jiný problém. Jde o to, že budeme provádět dělení tolikrát, kolik je prvků v našem poli. A vychází nám, že děláme velké množství zbytečných operací, protože dělení bychom mohli provést až na konci - jednou, vydělením celého nalezeného součtu.
Pojďme optimalizovat náš kód:
let sum = 0;
for (let elem of arr) {
sum += elem;
}
let avg = sum / arr.length;
console.log(avg);
Optimalizujte následující kód:
for (let i = 1900; i <= 2100; i++) {
let curr = new Date;
let date = new Date(i, curr.getMonth(), curr.getDate());
if (curr.getDay() === date.getDay()) {
console.log(date);
}
}
Optimalizujte následující kód:
let obj = {a: 10, b: 20, c: 30, d: 40, e: 50};
let sum = 0;
for (let key in obj) {
if (String(obj[key])[0] === '1' || String(obj[key])[0] === '2') {
sum += obj[key];
}
}
console.log(sum);