⊗jsSpOtLO 272 of 294 menu

JavaScript-ում ցիկլային օպերացիաների օպտիմիզացիա

Նույնիսկ թեթև օպերացիան, բազմակի կրկնվելով ցիկլում, կարող է զգալի ռեսուրսներ ծախսել:

Դիտարկենք մի օրինակ: Ենթադրենք, մենք ունենք որոշակի զանգված.

let arr = [1, 2, 3, 4, 5, 6];

Գտնենք այդ զանգվածի տարրերի միջին արժեքը: Դրա համար անհրաժեշտ է գտնել տարրերի գումարը և բաժանել այն տարրերի քանակի վրա: Ենթադրենք, ինչ-որ ծրագրավորող արդեն լուծել է այս խնդիրը հետևյալ կերպ.

let avg = 0; for (let elem of arr) { avg += elem / arr.length; } console.log(avg);

Դիտարկենք այս լուծման խնդիրները: Տեխնիկապես կոդը աշխատում է ճիշտ և տալիս է ճիշտ պատասխան: Բանն այն է, որ մաթեմատիկորեն ճիշտ է ինչպես ամբողջ գումարը բաժանել քանակի վրա, այնպես էլ յուրաքանչյուր գումարելի բաժանել քանակի վրա:

Սակայն, առաջանում է մեկ այլ խնդիր: Բանն այն է, որ մենք կկատարենք բաժանման գործողություն այնքան անգամ, որքան տարր կա մեր զանգվածում: Եվ ստացվում է, որ մենք անում ենք մեծ քանակությամբ ավելորդ գործողություններ, քանի որ բաժանումը կարելի էր կատարել վերջում՝ մեկ անգամ, բաժանելով ամբողջ գտնված գումարը:

Եկեք օպտիմիզացնենք մեր կոդը.

let sum = 0; for (let elem of arr) { sum += elem; } let avg = sum / arr.length; console.log(avg);

Օպտիմիզացրեք հետևյալ կոդը.

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); } }

Օպտիմիզացրեք հետևյալ կոդը.

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);
Հայերեն
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Մենք օգտագործում ենք cookie-ներ կայքի աշխատանքի, վերլուծության և անհատականացման համար։ Տվյալների մշակումը կատարվում է համաձայն Գաղտնիության քաղաքականության։
ընդունել բոլորը կարգավորել մերժել