HTML Diff
0 added 0 removed
Original 2026-01-01
Modified 2026-02-26
1 <p>Агрегация данных - наиболее важная операция при работе с деревьями. Подсчитать общее число файлов в директории, общий размер всех файлов, получить список всех файлов, найти все файлы по шаблону, все это - примеры агрегирования данных.</p>
1 <p>Агрегация данных - наиболее важная операция при работе с деревьями. Подсчитать общее число файлов в директории, общий размер всех файлов, получить список всех файлов, найти все файлы по шаблону, все это - примеры агрегирования данных.</p>
2 <p>Ключевой момент в агрегирующих операциях - это накопление результата. Для этой задачи хорошо подходит обход дерева в глубину с использованием рекурсивного процесса, который подробно рассматривается в предыдущем уроке. С его помощью мы обходим все узлы дерева и собираем результат, начиная с самого нижнего уровня. В этом уроке мы погрузимся в эти темы и научимся на практике реализовывать агрегацию.</p>
2 <p>Ключевой момент в агрегирующих операциях - это накопление результата. Для этой задачи хорошо подходит обход дерева в глубину с использованием рекурсивного процесса, который подробно рассматривается в предыдущем уроке. С его помощью мы обходим все узлы дерева и собираем результат, начиная с самого нижнего уровня. В этом уроке мы погрузимся в эти темы и научимся на практике реализовывать агрегацию.</p>
3 <h2>Как работает агрегация</h2>
3 <h2>Как работает агрегация</h2>
4 <p>Рассмотрим агрегацию с использованием рекурсивного процесса на примере подсчета общего количества узлов в дереве. Другими словами, попробуем выяснить, сколько всего файлов и директорий содержится в нашем файловом дереве:</p>
4 <p>Рассмотрим агрегацию с использованием рекурсивного процесса на примере подсчета общего количества узлов в дереве. Другими словами, попробуем выяснить, сколько всего файлов и директорий содержится в нашем файловом дереве:</p>
5 <p>Кода здесь немного, но он неочевидный. Есть несколько ключевых моментов:</p>
5 <p>Кода здесь немного, но он неочевидный. Есть несколько ключевых моментов:</p>
6 <ol><li>Функция проверяет тип узла:</li>
6 <ol><li>Функция проверяет тип узла:</li>
7 </ol><ul><li>Если узел - это файл, тогда из функции возвращается единица</li>
7 </ol><ul><li>Если узел - это файл, тогда из функции возвращается единица</li>
8 <li>Если узел - это директория, тогда получаем потомков и для каждого потомка вновь вызываем нашу функцию, затем повторяем алгоритм заново</li>
8 <li>Если узел - это директория, тогда получаем потомков и для каждого потомка вновь вызываем нашу функцию, затем повторяем алгоритм заново</li>
9 </ul><ol><li>Вызов функции на каждом потомке возвращает свой собственный результат - количество его потомков. Эти результаты образуют список с числами, которые нужно объединить</li>
9 </ul><ol><li>Вызов функции на каждом потомке возвращает свой собственный результат - количество его потомков. Эти результаты образуют список с числами, которые нужно объединить</li>
10 <li>В конце считаем общее количество всех потомков узла и добавляем к нему единицу (она обозначает текущий узел сам по себе)</li>
10 <li>В конце считаем общее количество всех потомков узла и добавляем к нему единицу (она обозначает текущий узел сам по себе)</li>
11 </ol><p>Перед тем, как двигаться дальше, поизучайте этот код и попрактикуйтесь локально на своем компьютере. Это единственный способ разобраться с такой неочевидной темой как агрегация.</p>
11 </ol><p>Перед тем, как двигаться дальше, поизучайте этот код и попрактикуйтесь локально на своем компьютере. Это единственный способ разобраться с такой неочевидной темой как агрегация.</p>
12 <h2>Рекомендуемые программы</h2>
12 <h2>Рекомендуемые программы</h2>