PHP-dä siklda massiwiň uzynlygyny gerek däl hasaplamak
Sanlardan ybarat bir massiw berlen diýeliň:
<?php
$arr = [1, 2, 3, 4, 5];
?>
Massiwiň her bir elementini kwadrat ýaýalyň. Ýagny, bizde hili sanlaryň kwadratlary bilen şol bir $arr massiw galmaly.
Şeýle ýagdaýda foreach sikli ýaramaz, adaty for sikli massiw üçin zerur, şeýle:
<?php
$arr = [1, 2, 3, 4, 5];
for ($i = 0; $i < count($arr); $i++) {
$arr[$i] = $arr[$i] * $arr[$i]; // massiwiň her bir elementini üýtgedýäris
}
var_dump($arr);
?>
Bu kod bilen näme ýalňyş? Problema şonda, count($arr) sikl her iterasiýasynda manysyz hasaplanyar! Näme üçin, sebäbi siklda massiwiň uzynlygy üýtgemeýär, dogrymy?
Optimalaşdyrmak üçin massiwiň uzynlygyny hasaplamany aýratyn üýtgeýjige geçirýäris:
<?php
$arr = [1, 2, 3, 4, 5];
$len = count($arr); // optimalaşdyrýarys
for ($i = 1; $i < $len; $i++) {
$arr[$i] = $arr[$i] * $arr[$i];
}
var_dump($arr);
?>
Aşakda berlen kody optimalaşdyryň:
<?php
$arr = [1, 2, 2, 4, 5];
for ($i = 1; $i < count($arr); $i++) {
if ($arr[$i - 1] === $arr[$i]) {
echo $arr[$i] . '<br>';
}
}
?>