КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Рекурсивна функція і рекурсивна процедура
Вправи Питання для роздумів Перевірка складної умови, перевірка складної комбінації простих умов, декларативний стиль програмування, процедурний стиль програмування, сортування чисел, перестановка, число перестановок.
Прикметник рекурсивний найчастіше відносять до деяких об'єктів з області математики чи близьких до неї наук (у тому числі інформатики). Коротше кажучи, об'єкт рекурсивний, якщо він визначається через самого себе. В інформатиці і програмуванні рекурсивні об'єкти зустрічаються досить часто. Ви з ними вже зіштовхнулися: це арифметичні і логічні вирази. А тут ми розглянемо інший різновид таких об'єктів — рекурсивні функції і процедури. Рекурсивні функції і процедури дуже популярні в сучасних мовах програмування. З їхньою допомогою програмування багатьох задач, що спочатку здається важкою справою, виявляється простим і витонченим. Що ж таке рекурсивний об'єкт (зокрема, рекурсивна функція і рекурсивна процедура)? Спробуємо більш точно розібратися в цих непростих поняттях. Об'єкт називається рекурсивним об'єктом, якщо він цілком чи частково визначається через самого себе. Приклад рекурсивного об'єкта, що цілком визначається через самого себе, — це загальновідома епітафія, що записав деякий піп на пам'ятнику своєму собаці (Згадайте: «У попа був собака, він її любив, вона з'їла шматок м'яса, він її убив. І в землю закопав, і пам'ятник поставив, і напис написав, що в попа був собака, він її любив, вона з'їла шматок м'яса, він її убив. І в землю закопав,... і т.д. до нескінченності».). Об'єкти, що визначаються через себе, практичного інтересу не представляють, тому що є нескінченними. Їх приводять як забавний курйоз, на зразок згаданої епітафії. Але об'єкти, що визначаються через себе частково, використовуються і на практиці. Яскравий приклад — визначення факторіала натурального числа в математиці. Факторіалом натурального числа N називається така функція, що повертає добуток усіх натуральних чисел від одиниці до даного числа. Крім того, умовно вважається, що факторіалом нуля є одиниця. Позначимо (Звичайно для позначення факторіала числа N використовується знак оклику: N!. Але тут ми не хочемо, щоб виникла плутанина, тому що за допомогою N! ми позначаємо змінну типу Single.) цю функцію так: Фaкmopіaл(N). Приклади значень факторіала: Факторіал(0)=1; Факторіал(3)=6; Факторіал(6)=720. Факторіал числа можна визначити через сам факторіал: якщо N дорівнює нулю, то Фaкmopіaл(N) дорівнює одиниці; якщо ж N більше нуля, то Фaкmopіaл(N) дорівнює числу N, помноженому на Факторіал(N-І). Чому факторіал лише частково визначається через самого себе? Відповідь така: факторіал числа визначається через факторіал меншого на одиницю числа. Тому процес «повторного визначення рано чи пізно закінчиться. Формально визначення рекурсивних функцій і процедур нічим не відрізняються від описаних визначень звичайних (нерекурсивних) функцій і процедур. Щоб не повторюватися, зараз ми будемо говорити тільки про функції, але все це повною мірою буде відноситися і до процедур. Між першим і останнім рядками визначення функції розміщаються ВиконуваніОператори. Серед них може бути й оператор виклику самої обумовленої функції. Виконання цього оператора називається рекурсивним викликом чи просто рекурсією. Рекурсивна функція (процедура) — це така функція (процедура), серед ВиконуванихОператорів, якою є оператор виклику самої цієї функції (процедури). Якби при роботі рекурсивної функції рекурсивні виклики виконувалися без всяких умов, її робота ніколи б не закінчилася. Тому серед ВиконуванихОператорі обов'язково повинна бути умова завершення (продовження) рекурсії. Послідовність рекурсивних викликів називається рекурсивним спуском. Номер рекурсивного виклику в цій послідовності називається глибиною рекурсії. Серед ВиконуванихОператорів у визначенні функції можуть бути такі, котрі виконують деяку дію і які розташовані до оператора рекурсивного виклику. Вони виконуються в тому порядку, у якому відбуваються рекурсивні виклики. Говорять, що дія виконується на рекурсивному спуску. Серед ВиконуванихОператорів у визначенні функції можуть бути і такі, котрі теж виконують деяку дію і які розташовані після оператора рекурсивного виклику. Вони виконуються в порядку, зворотному тому, у якому відбуваються рекурсивні виклики. Говорять, що дія виконується на рекурсивному підйомі. Приклад 3.2. Приведемо визначення двох рекурсивних функцій Факторіал 1 і Факторіал 2, кожна з яких повертає факторіал даного числа. У першій з них дія виконується на рекурсивному спуску, а в другій - на рекурсивному підйомі.
Функція Факторіал 1 є функцією трьох аргументів. Крім натурального Числа, факторіал якого вона повертає, у неї є ще два аргументи: Індекс і Добуток. Їхні початкові значення дорівнюють одиниці. У ході рекурсивного спуска Індекс щораз збільшується (іноді для простоти замість того, щоб говорити: «Значення змінної А дорівнює значенню змінної Б», ми будемо говорити: «А дорівнює Б») на одиницю, а Добутку привласнюється значення, рівне добутку його старого значення на Індекс. Під час останнього рекурсивного виклику, коли Індекс стане рівним Числу, Добуток стане рівним факторіалу цього Числа. На рекурсивному підйомі робити вже нічого не треба.
Функція Факторіал 2 — це функція всього одного аргументу, — Числа. При кожному рекурсивному виклику Число зменшується на одиницю і ніяке множення при цьому не робиться. І тільки після останнього рекурсивного виклику, коли Число стане рівним одиниці, почне робитися послідовне множення на рекурсивному підйомі: 1*1 -> 1*2 -> 2*3 -> 6*4 ->... По швидкодії і по обсягу оперативної пам'яті комп'ютера, який вимагає виконання кожної з цих функцій, вони приблизно рівні. Hові поняття:
Дата добавления: 2014-12-23; Просмотров: 909; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |