77415-1 (751185)
Текст из файла
Использование рекурсии в PHP
Дроздовский Михаил
Рекурсия — это обращение функции к самой себе.
Многие не понимают, как же использовать рекурсию на практике — мол, "что за бред, функция обращается сама к себе... Этого не должно быть!". Действительно, кажется странновато и неудобно. Ну что же, разберем реальный случай.
Допустим, нам необходимо выстроить дерево записей из базы данных, каждый из которых имеет следующие параметры:
| uid | имя записи | uid родительской записи |
Вроде, все просто — сделал код типа
$s = mysql_query("SELECT * FROM x_table WHERE parent_id=0", $conn);
while ($z = mysql_fetch_array($s)) {
...
$x = mysql_query("SELECT * FROM x_table WHERE parent_id=".$z["uid"], $conn);
while ($f = mysql_fetch_array($x)) {
...
и т.д.
}
}
Но ведь количество уровней вложенности может быть неограниченным! Получается, количество циклов будет бесконечным, длина кода будет бесконечной итп. Т.е. сделать ничего не получится. Как же быть.
Некоторые программисты просидят над этой задачей довольно долго. Конечно, можно сделать 100 циклов, в надежде, что такой глубокой вложенности записей не будет. А если будет? К тому же код с 100 циклами будет плохочитаемым, длинным и очень объемным. Ну а если там появится небольшая ошибка... (дальше, я думаю, объяснять не стоит).
-------------------------
Эту задачу достаточно легко решить с помощью рекурсии. Пишем небольшую функцию:
function tree($uid, $conn) {
$sql = "SELECT * FROM x_table WHERE parent_id=$uid";
$a = mysql_query($sql, $conn);
while($x = mysql_fetch_array($a)) {
.... какие-то действия...
tree($x["uid"], $conn);
}
}
И запускаем ее: tree(0, $conn). Все. Сложная на вид задача решена.
Эпилог: с подобной задачей автор столкнулся при написании одного веб-приложения на PHP.
Список литературы
Для подготовки данной работы были использованы материалы с сайта http://progcpp.narod.ru/
Характеристики
Тип файла документ
Документы такого типа открываются такими программами, как Microsoft Office Word на компьютерах Windows, Apple Pages на компьютерах Mac, Open Office - бесплатная альтернатива на различных платформах, в том числе Linux. Наиболее простым и современным решением будут Google документы, так как открываются онлайн без скачивания прямо в браузере на любой платформе. Существуют российские качественные аналоги, например от Яндекса.
Будьте внимательны на мобильных устройствах, так как там используются упрощённый функционал даже в официальном приложении от Microsoft, поэтому для просмотра скачивайте PDF-версию. А если нужно редактировать файл, то используйте оригинальный файл.
Файлы такого типа обычно разбиты на страницы, а текст может быть форматированным (жирный, курсив, выбор шрифта, таблицы и т.п.), а также в него можно добавлять изображения. Формат идеально подходит для рефератов, докладов и РПЗ курсовых проектов, которые необходимо распечатать. Кстати перед печатью также сохраняйте файл в PDF, так как принтер может начудить со шрифтами.