1 added
1 removed
Original
2026-01-01
Modified
2026-02-26
1
<p>Есть отдельный класс задач, который не может обойтись без циклов - он называется<strong>агрегированием данных</strong>. К таким задачам относятся поиск максимального и минимального значения, вычисление суммы и среднего арифметического и так далее. Их главная особенность в том, что результат зависит от всего набора данных. Для расчета суммы нужно сложить<strong>все</strong>числа, для вычисления максимального нужно сравнить<strong>все</strong>числа.</p>
1
<p>Есть отдельный класс задач, который не может обойтись без циклов - он называется<strong>агрегированием данных</strong>. К таким задачам относятся поиск максимального и минимального значения, вычисление суммы и среднего арифметического и так далее. Их главная особенность в том, что результат зависит от всего набора данных. Для расчета суммы нужно сложить<strong>все</strong>числа, для вычисления максимального нужно сравнить<strong>все</strong>числа.</p>
2
<p>С такими задачами хорошо знакомы те, кто занимаются числами - например, бухгалтеры или маркетологи. Обычно их выполняют в таблицах в Microsoft Excel или Google Sheets. Именно эту тему мы изучим в этом уроке.</p>
2
<p>С такими задачами хорошо знакомы те, кто занимаются числами - например, бухгалтеры или маркетологи. Обычно их выполняют в таблицах в Microsoft Excel или Google Sheets. Именно эту тему мы изучим в этом уроке.</p>
3
<p>Разберем самый простой пример - поиск суммы набора чисел. Реализуем функцию, которая складывает числа в указанном диапазоне, включая границы. Диапазоном в данном случае называется ряд чисел от какого-то начала до определенного конца. Например, диапазон [1, 10] включает в себя все целые числа от 1 до 10.</p>
3
<p>Разберем самый простой пример - поиск суммы набора чисел. Реализуем функцию, которая складывает числа в указанном диапазоне, включая границы. Диапазоном в данном случае называется ряд чисел от какого-то начала до определенного конца. Например, диапазон [1, 10] включает в себя все целые числа от 1 до 10.</p>
4
<p>Для реализации этого кода нам понадобится цикл по двум причинам:</p>
4
<p>Для реализации этого кода нам понадобится цикл по двум причинам:</p>
5
<ul><li>Сложение чисел - это итеративный процесс, то есть он повторяется для каждого числа</li>
5
<ul><li>Сложение чисел - это итеративный процесс, то есть он повторяется для каждого числа</li>
6
<li>Количество итераций зависит от размера диапазона</li>
6
<li>Количество итераций зависит от размера диапазона</li>
7
</ul><p>Перед тем, как смотреть код, попробуйте ответить на вопросы ниже:</p>
7
</ul><p>Перед тем, как смотреть код, попробуйте ответить на вопросы ниже:</p>
8
<ul><li>Каким значением инициализировать счетчик?</li>
8
<ul><li>Каким значением инициализировать счетчик?</li>
9
<li>Как он будет изменяться?</li>
9
<li>Как он будет изменяться?</li>
10
<li>Когда цикл должен остановиться?</li>
10
<li>Когда цикл должен остановиться?</li>
11
</ul><p>Попробуйте сначала подумать над этими вопросами, а затем посмотрите код ниже:</p>
11
</ul><p>Попробуйте сначала подумать над этими вопросами, а затем посмотрите код ниже:</p>
12
<p>Общая структура цикла здесь стандартна. В нем есть три компонента:</p>
12
<p>Общая структура цикла здесь стандартна. В нем есть три компонента:</p>
13
<ul><li>Счетчик, который инициализируется начальным значением диапазона</li>
13
<ul><li>Счетчик, который инициализируется начальным значением диапазона</li>
14
<li>Сам цикл с условием остановки при достижении конца диапазона</li>
14
<li>Сам цикл с условием остановки при достижении конца диапазона</li>
15
<li>Изменение счетчика в конце тела цикла</li>
15
<li>Изменение счетчика в конце тела цикла</li>
16
</ul><p>Количество итераций в таком цикле равно $finish - $start + 1. То есть для диапазона от 5 до 7 - это 7 - 5 + 1, то есть три итерации.</p>
16
</ul><p>Количество итераций в таком цикле равно $finish - $start + 1. То есть для диапазона от 5 до 7 - это 7 - 5 + 1, то есть три итерации.</p>
17
<p>Главные отличия от обычной обработки связаны с логикой вычислений результата. В задачах на агрегацию всегда есть какая-то переменная, которая хранит внутри себя результат работы цикла. В коде выше это $sum. На каждой итерации цикла происходит ее изменение, прибавление следующего числа в диапазоне: $sum = $sum + $i.</p>
17
<p>Главные отличия от обычной обработки связаны с логикой вычислений результата. В задачах на агрегацию всегда есть какая-то переменная, которая хранит внутри себя результат работы цикла. В коде выше это $sum. На каждой итерации цикла происходит ее изменение, прибавление следующего числа в диапазоне: $sum = $sum + $i.</p>
18
<p>Весь процесс выглядит так:</p>
18
<p>Весь процесс выглядит так:</p>
19
<p>У переменной $sum есть начальное значение, равное 0. Зачем вообще задавать значение? Любая повторяющаяся операция начинается с какого-то значения. Нельзя просто так объявить переменную и начать с ней работать внутри цикла. Это может приводить к ошибкам:</p>
19
<p>У переменной $sum есть начальное значение, равное 0. Зачем вообще задавать значение? Любая повторяющаяся операция начинается с какого-то значения. Нельзя просто так объявить переменную и начать с ней работать внутри цикла. Это может приводить к ошибкам:</p>
20
<p>В результате такого вызова внутри $sum окажется верный результат, но интерпретатор выведет ошибку: PHP Notice: Undefined variable: sum. Она возникает из-за попытки использовать неопределенную переменную. Значит какое-то значение все же нужно. Почему в коде выше выбран 0? Очень легко проверить, что все остальные варианты приведут к неверному результату. Если начальное значение будет равно 1, то результат получится на 1 больше, чем нужно.</p>
20
<p>В результате такого вызова внутри $sum окажется верный результат, но интерпретатор выведет ошибку: PHP Notice: Undefined variable: sum. Она возникает из-за попытки использовать неопределенную переменную. Значит какое-то значение все же нужно. Почему в коде выше выбран 0? Очень легко проверить, что все остальные варианты приведут к неверному результату. Если начальное значение будет равно 1, то результат получится на 1 больше, чем нужно.</p>
21
<p>В математике у каждой операции существует<strong>нейтральный элемент этой операции</strong>. Операция с этим элементом не изменяет то значение, над которым проводится операция:</p>
21
<p>В математике у каждой операции существует<strong>нейтральный элемент этой операции</strong>. Операция с этим элементом не изменяет то значение, над которым проводится операция:</p>
22
<ul><li>Ноль при сложении: любое число + ноль = само число</li>
22
<ul><li>Ноль при сложении: любое число + ноль = само число</li>
23
<li>Ноль при вычитании: любое число - ноль = само число</li>
23
<li>Ноль при вычитании: любое число - ноль = само число</li>
24
<li>Пустая строка при конкатенации: '' + 'string' будет 'string'</li>
24
<li>Пустая строка при конкатенации: '' + 'string' будет 'string'</li>
25
</ul><h2>Агрегация данных (Строки)</h2>
25
</ul><h2>Агрегация данных (Строки)</h2>
26
<p>Агрегация применяется не только к числам, но и к строкам. Это такие задачи, в которых строка формируется динамически - то есть заранее неизвестно, какого она размера и что будет содержать.</p>
26
<p>Агрегация применяется не только к числам, но и к строкам. Это такие задачи, в которых строка формируется динамически - то есть заранее неизвестно, какого она размера и что будет содержать.</p>
27
<p>Представьте себе функцию, которая умеет умножать строку, то есть повторять ее указанное количество раз:</p>
27
<p>Представьте себе функцию, которая умеет умножать строку, то есть повторять ее указанное количество раз:</p>
28
<p>Принцип работы этой функции довольно простой - в цикле происходит "наращивание" строки указанное количество раз:</p>
28
<p>Принцип работы этой функции довольно простой - в цикле происходит "наращивание" строки указанное количество раз:</p>
29
<p>Распишем выполнение этого кода по шагам:</p>
29
<p>Распишем выполнение этого кода по шагам:</p>
30
<h2>Обход строк</h2>
30
<h2>Обход строк</h2>
31
<p>Циклы подходят не только для обработки чисел, но и при работе со строками - и это благодаря возможности получить конкретный символ по его индексу. Ниже пример кода, который распечатывает буквы каждого слова на отдельной строке:</p>
31
<p>Циклы подходят не только для обработки чисел, но и при работе со строками - и это благодаря возможности получить конкретный символ по его индексу. Ниже пример кода, который распечатывает буквы каждого слова на отдельной строке:</p>
32
<p>Самое главное в этом коде - поставить правильное условие в while. Это можно сделать сразу двумя способами:</p>
32
<p>Самое главное в этом коде - поставить правильное условие в while. Это можно сделать сразу двумя способами:</p>
33
<ul><li>$i < strlen($name)</li>
33
<ul><li>$i < strlen($name)</li>
34
<li>$i <= strlen($name) - 1</li>
34
<li>$i <= strlen($name) - 1</li>
35
</ul><p>Оба способа приводят к одному результату.</p>
35
</ul><p>Оба способа приводят к одному результату.</p>
36
<h2>Формирование строк в циклах</h2>
36
<h2>Формирование строк в циклах</h2>
37
<p>Еще одно использование циклов - формирование строк. Подобная задача нередко встречается в веб-программировании. Она сводится к обычной агрегации с применением интерполяции или конкатенации.</p>
37
<p>Еще одно использование циклов - формирование строк. Подобная задача нередко встречается в веб-программировании. Она сводится к обычной агрегации с применением интерполяции или конкатенации.</p>
38
<p>Есть одна задача, крайне популярная на собеседованиях - это<strong>переворот строки</strong>. Ее можно решить множеством разных способов, но именно посимвольный перебор считается базовым.</p>
38
<p>Есть одна задача, крайне популярная на собеседованиях - это<strong>переворот строки</strong>. Ее можно решить множеством разных способов, но именно посимвольный перебор считается базовым.</p>
39
<p>Рассмотрим пример работы этой функции:</p>
39
<p>Рассмотрим пример работы этой функции:</p>
40
-
<p>Общая идея переворота состоит в следующем - нужно брать символы по очереди с начала строки и соединять их в обратном порядке. Звучит довольно просто. Давайте проверим:</p>
40
+
<p>Общая идея переворота состоит в следующем �� нужно брать символы по очереди с начала строки и соединять их в обратном порядке. Звучит довольно просто. Давайте проверим:</p>
41
<p>Единственный сложный момент в этом коде - прочувствовать, как собирается сама строка. Так как каждый следующий символ прикрепляется к результирующей строке слева, то, в конечном итоге, строка оказывается перевернута.</p>
41
<p>Единственный сложный момент в этом коде - прочувствовать, как собирается сама строка. Так как каждый следующий символ прикрепляется к результирующей строке слева, то, в конечном итоге, строка оказывается перевернута.</p>