Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
20 / 20 / 13
Регистрация: 22.11.2015
Сообщений: 109

Стоит ли применять рекурсивные функции?

02.06.2016, 03:22. Показов 1348. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, есть вопросик.
Подскажите, пожалуйста, а вообще в средних или больших проектах применяют рекурсию?
Ведь рекурсия более затратна, чем фор-подобные циклы.
Спасибо
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.06.2016, 03:22
Ответы с готовыми решениями:

Рекурсивные и не рекурсивные функции (вычисление суммы всех натуральных чисел от 1 до n)
Всем привет. Заранее извиняюсь за мб глупые вопросы и навязчивость. Но у меня есть одна просьба. Помогите пожалуйста написать...

Где стоит применять Entity Bean?
Ситуация - имеем 5 таблиц, одна из которых находится в центре идущих к ней связей от других таблиц. Для каждой таблицы создан Entity bean....

Стоит ли для адаптивности применять тег picture?
Ребят, подскажите, стоит ли вместо медиазапросов для изменения изображений использовать тег <picture>? Вместе с подключением скрипта...

2
504 / 247 / 75
Регистрация: 31.10.2010
Сообщений: 747
02.06.2016, 04:51
Михаил_96, если 1-2 рекурсивных вызова, то возможно (но не очень желательно),
если больше то категорически нет. Рекурсивные вызовы, практически на всех языках очень тормозные, т.к. при каждом вызове требуется сохранять кучу данных в стек (или кешь), а потом извлекать их оттуда, JS и так не быстрый язык, а рекурсия нагрузит дополнительно.
Безусловно могут быть исключения, но они лишь подтверждают правила. Если учебная задача и необходимо реализовать рекурсию, то почему нет? А если необходимо написать быстрые скрипты, то однозначно нет.
В общем случае, рекурсия, хороша как теоретическая основа изучения многих явлений и объектов, например, биологических форм жизни, фракталов и проч.
Для программирования рекурсию возможно применять только в задачах где есть "излишки" вычислительных ресурсов (машинного времени, памяти). Для быстродействия, лучше отказываться от рекурсии в пользу циклов.
При этом следует отметить, что с помощью рекурсии часто можно написать внешне очень элегантный код, но, в большинстве случаев, такой элегантный код значительно проиграет в быстродействии циклам (хорошо написанным).
Рекурсию, в смысле быстродействия, можно сравнить с беременностью и родами, циклы это как непосредственное клеточное деление -- работает намного быстрее.
Но! Есть специальные языки в которых рекурсивный программный код может быть развёрнут в циклы на языке процессора (машинные коды). JS -- к таким языкам не относится.
1
20 / 20 / 13
Регистрация: 22.11.2015
Сообщений: 109
02.06.2016, 05:09  [ТС]
Окей, понял. Спасибо

Не по теме:

Цитата Сообщение от RefSol Посмотреть сообщение
JS и так не быстрый язык
Но здесь я бы с вами поспорил :)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.06.2016, 05:09
Помогаю со студенческими работами здесь

В каких случаях стоит применять метод File.AppendText()?
Думал, что File.AppendText - простая надстройка над using (StreamWriter sw = new StreamWriter(path)) { ...

String в классе (конструктор): когда стоит применять указатели и динамическое выделение памяти?
Добрый вечер всем. Я вот начал писать для себя одну программку по книжке Стэнли Липманна, в общем хочу понять кое-что: предположим, у меня...

Стоит ли в C++ Builder применять такие типы как TCHAR, WCHAR, LPSTR, LPWSTR, LPCTSTR
Здравствуйте. Стоит ли в C++ Builder применять такие типы как TCHAR, WCHAR, LPSTR, LPWSTR, LPCTSTR и тп ? Потому что в VS++ Нет как...

Использовать циклы запрещено, вместо них стоит применить рекурсивные вызовы
Доброго времени суток! есть задача: #include <cmath> #include <iostream> #include <time.h> #include...

Стоит ли изучать все досконально, или пытаться применять все уже сейчас?
Добрый день, форумчане. Мне 16 лет (да неважно, в принципе), я люблю программирование. Сталкиваюсь с такой проблемой - чем больше выучил,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru