HTML Diff
0 added 0 removed
Original 2026-01-01
Modified 2026-02-26
1 <p>В программировании есть отдельный класс задач, который не может обойтись без циклов - он называется<strong>агрегированием данных</strong>.</p>
1 <p>В программировании есть отдельный класс задач, который не может обойтись без циклов - он называется<strong>агрегированием данных</strong>.</p>
2 <p>К таким задачам относится поиск:</p>
2 <p>К таким задачам относится поиск:</p>
3 <ul><li>Максимального значения</li>
3 <ul><li>Максимального значения</li>
4 <li>Минимального значения</li>
4 <li>Минимального значения</li>
5 <li>Суммы</li>
5 <li>Суммы</li>
6 <li>Среднего арифметического</li>
6 <li>Среднего арифметического</li>
7 </ul><p>Их главная особенность в том, что результат зависит от всего набора данных. Для расчета суммы нужно сложить<strong>все</strong>числа, для вычисления максимального нужно сравнить<strong>все</strong>числа.</p>
7 </ul><p>Их главная особенность в том, что результат зависит от всего набора данных. Для расчета суммы нужно сложить<strong>все</strong>числа, для вычисления максимального нужно сравнить<strong>все</strong>числа.</p>
8 <p>С этой темой хорошо знакомы все, кто занимаются числами. Например, с такими задачами часто работают бухгалтеры или маркетологи в таблицах наподобие Microsoft Excel или Google Sheets.</p>
8 <p>С этой темой хорошо знакомы все, кто занимаются числами. Например, с такими задачами часто работают бухгалтеры или маркетологи в таблицах наподобие Microsoft Excel или Google Sheets.</p>
9 <p>Разберем самый простой пример - поиск суммы набора чисел. Реализуем функцию, которая складывает числа в указанном диапазоне, включая границы.</p>
9 <p>Разберем самый простой пример - поиск суммы набора чисел. Реализуем функцию, которая складывает числа в указанном диапазоне, включая границы.</p>
10 <p>В этом случае<strong>диапазоном</strong>называется ряд чисел от какого-то начала до определенного конца. Например, диапазон [1, 10] включает в себя все целые числа от 1 до 10:</p>
10 <p>В этом случае<strong>диапазоном</strong>называется ряд чисел от какого-то начала до определенного конца. Например, диапазон [1, 10] включает в себя все целые числа от 1 до 10:</p>
11 <p>Для реализации этого кода нам понадобится цикл. Мы выбираем именно цикл, потому что сложение чисел - это итеративный процесс. Он повторяется для каждого числа, а количество итераций зависит от размера диапазона.</p>
11 <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>А теперь посмотрите код ниже:</p>
16 </ul><p>А теперь посмотрите код ниже:</p>
17 <p>Общая структура цикла здесь стандартна:</p>
17 <p>Общая структура цикла здесь стандартна:</p>
18 <ul><li>Счетчик, который инициализируется начальным значением диапазона</li>
18 <ul><li>Счетчик, который инициализируется начальным значением диапазона</li>
19 <li>Сам цикл с условием остановки при достижении конца диапазона</li>
19 <li>Сам цикл с условием остановки при достижении конца диапазона</li>
20 <li>Изменение счетчика в конце тела цикла</li>
20 <li>Изменение счетчика в конце тела цикла</li>
21 </ul><p>Количество итераций в таком цикле равно finish - start + 1. Например, нужно 3 итерации, чтобы посчитать диапазон от 5 до 7:</p>
21 </ul><p>Количество итераций в таком цикле равно finish - start + 1. Например, нужно 3 итерации, чтобы посчитать диапазон от 5 до 7:</p>
22 <p>Главные отличия от обычной обработки связаны с логикой вычислений результата. В задачах на агрегацию всегда есть какая-то переменная, которая хранит внутри себя результат работы цикла. В коде выше это sum.</p>
22 <p>Главные отличия от обычной обработки связаны с логикой вычислений результата. В задачах на агрегацию всегда есть какая-то переменная, которая хранит внутри себя результат работы цикла. В коде выше это sum.</p>
23 <p>На каждой итерации цикла происходит ее изменение, прибавление следующего числа в диапазоне: sum = sum + i. Весь процесс выглядит так:</p>
23 <p>На каждой итерации цикла происходит ее изменение, прибавление следующего числа в диапазоне: sum = sum + i. Весь процесс выглядит так:</p>
24 <p>В математике существует понятие<strong>нейтральный элемент операции</strong>. Операция с таким элементом не изменяет то значение, над которым проводится операция:</p>
24 <p>В математике существует понятие<strong>нейтральный элемент операции</strong>. Операция с таким элементом не изменяет то значение, над которым проводится операция:</p>
25 <ul><li>В сложении любое число плюс ноль дает само число</li>
25 <ul><li>В сложении любое число плюс ноль дает само число</li>
26 <li>При вычитании - то же самое</li>
26 <li>При вычитании - то же самое</li>
27 <li>Даже у конкатенации есть нейтральный элемент - это пустая строка: "" + "one" будет "one"</li>
27 <li>Даже у конкатенации есть нейтральный элемент - это пустая строка: "" + "one" будет "one"</li>
28 </ul><p>В примере выше число ноль, которым мы инициализируем переменную для хранения суммы, как раз и есть нейтральный элемент операции сложения. Такое начальное значение никак не исказит итоговый результат, потому что при сложении с нулем любой другой элемент остается неизменным</p>
28 </ul><p>В примере выше число ноль, которым мы инициализируем переменную для хранения суммы, как раз и есть нейтральный элемент операции сложения. Такое начальное значение никак не исказит итоговый результат, потому что при сложении с нулем любой другой элемент остается неизменным</p>