![]() |
Модераторы: skyboy, MoLeX, Aliance, ksnk |
![]() ![]() ![]() |
|
DezmASter |
|
||||
![]() Дизайнер :) ![]() ![]() ![]() Профиль Группа: Участник Сообщений: 1520 Регистрация: 3.2.2006 Где: Украина, Запорожь е Репутация: 1 Всего: 109 |
Рекурсия — это обращение функции к самой себе.
Многие не понимают, как же использовать рекурсию на практике — мол, "что за бред, функция обращается сама к себе... Этого не должно быть!". Действительно, кажется странновато и неудобно. Ну что же, разберем реальный случай. Допустим, нам необходимо выстроить дерево записей из базы данных, каждый из которых имеет следующие параметры:
Но ведь количество уровней вложенности может быть неограниченным! Получается, количество циклов будет бесконечным, длина кода будет бесконечной итп. Т.е. сделать ничего не получится. Как же быть. Некоторые программисты просидят над этой задачей довольно долго. Конечно, можно сделать 100 циклов, в надежде, что такой глубокой вложенности записей не будет. А если будет? К тому же код с 100 циклами будет плохочитаемым, длинным и очень объемным. Ну а если там появится небольшая ошибка... (дальше, я думаю, объяснять не стоит). Эту задачу достаточно легко решить с помощью рекурсии. Пишем небольшую функцию:
И запускаем ее: tree(0, $conn). Все. Сложная на вид задача решена. Эпилог: с подобной задачей автор столкнулся при написании одного веб-приложения на PHP. Автор: Дроздовский Михаил Сайт автора: http://journalist.artotron.com/ Это сообщение отредактировал(а) DezmASter - 26.4.2007, 13:08 |
||||
|
|||||
![]() ![]() ![]() |
Правила форума "PHP" | |
|
Новичкам:
Важно:
Внимание:
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, IZ@TOP, skyboy, SamDark, MoLeX, awers. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | PHP: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |