Реферат по предмету "Программирование"


Использование рекурсии в PHP

Использование рекурсии в 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/


Не сдавайте скачаную работу преподавателю!
Данный реферат Вы можете использовать для подготовки курсовых проектов.

Поделись с друзьями, за репост + 100 мильонов к студенческой карме :

Пишем реферат самостоятельно:
! Как писать рефераты
Практические рекомендации по написанию студенческих рефератов.
! План реферата Краткий список разделов, отражающий структура и порядок работы над будующим рефератом.
! Введение реферата Вводная часть работы, в которой отражается цель и обозначается список задач.
! Заключение реферата В заключении подводятся итоги, описывается была ли достигнута поставленная цель, каковы результаты.
! Оформление рефератов Методические рекомендации по грамотному оформлению работы по ГОСТ.

Читайте также:
Виды рефератов Какими бывают рефераты по своему назначению и структуре.

Сейчас смотрят :

Реферат Русский свет
Реферат Организация и планирование маркетинга на предприятии
Реферат Анализ кадрового менеджмента в гостинице АРЕНА
Реферат Учет вложений во внеоборотные активы 4
Реферат Ликвидационный баланс и порядок его составления
Реферат Системные противоречия всемирного исторического процесса.
Реферат Связь психологии с другими научными дисциплинами
Реферат Анализ себестоимости производства продукции растениеводства
Реферат Буржуазно-демократические революции
Реферат Україна 20-х - початку 30-х років. Нова економічна політика. Голодомор 1921-1922 рр.
Реферат Прибыль организации сферы услуг: комплексный анализ и пути ее увеличения
Реферат Привлечение дополнительных оборотных средств на предприятиях рекреационной сферы
Реферат Системы принятия решений, оптимизация в Excel и базы данных Access
Реферат Оплата труда в России
Реферат Мария Монтессори