HTML Diff
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 &lt; strlen($name)</li>
33 <ul><li>$i &lt; strlen($name)</li>
34 <li>$i &lt;= strlen($name) - 1</li>
34 <li>$i &lt;= 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>