⊗ppSpOtEI 76 of 83 menu

Аптымізацыя лішніх праходаў цыкла ў PHP

У наступным кодзе нейкі праграміст правярае, ці ёсць у масіве лік 3:

<?php $arr = [1, 2, 3, 4, 5, 6, 7, 8, 9]; $exists = false; foreach ($arr as $elem) { if ($elem == 3) { $exists = true; } } var_dump($exists); ?>

Што не так з яго рашэннем? Напэўна, ніякіх лішніх аперацый у цыкле не робіцца. Праблема, аднак, у тым, што пасля таго, як вызначана, што лік 3 ёсць у масіве - цыкл усё роўна працягвае круціцца да канца масіва.

Нерацыянальней за ўсё будзе, калі лік 3 знойдзецца дзе-небудзь у пачатку масіва, а сам масіў будзе доўгі, скажам, 1000 элементаў. Атрымаецца тысяча бескарысных лішніх ітэрацый цыкла! Не аптымальна.

Аптымізуем код, своечасова спыніўшы цыкл:

<?php $arr = [1, 2, 3, 4, 5, 6, 7, 8, 9]; $exists = false; foreach ($arr as $elem) { if ($elem == 3) { $exists = true; break; } } var_dump($exists); ?>

Наступны код падлічвае, колькі элементаў масіва трэба скласці, каб сума стала больш за 10. Выканайце аптымізацыю:

<?php $arr = [1, 2, 3, 4, 5, 6, 7, 8, 9]; $sum = 0; $i = 1; foreach ($arr as $elem) { $sum += $elem; if ($sum <= 10) { $i++; } } echo $i; ?>

Наступны код выводзіць цотныя лікі з зададзенага прамежку. Выканайце аптымізацыю:

<?php for ($i = 0; $i <= 100; $i++) { if ($i % 2 === 0) { echo $i; } } ?>

Наступны код выводзіць лікі, якія дзеляцца адначасова на 2 і на 3. Выканайце аптымізацыю:

<?php for ($i = 0; $i <= 100; $i++) { if ($i % 2 === 0 and $i % 3 === 0) { echo $i; } } ?>
Беларуская
AfrikaansAzərbaycanБългарскиবাংলাČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Мы выкарыстоўваем cookie для працы сайта, аналітыкі і персаналізацыі. Апрацоўка дадзеных адбываецца згодна Палітыкай канфідэнцыяльнасці.
прыняць усе наладзіць адхіліць