Loading...

Във форума е въведено ограничение, което позволява на потребителите единствено да разглеждат публикуваните въпроси.

SophYO avatar SophYO 74 Точки

JavaFund/ TribonacciSequence

Здравейте!

Моля за малко съдействие.

С това решение: https://pastebin.com/F8arzhvN ми дава 90/ 100, като е -10 p, заради time limit.

Някой дали има идея къде е и как се получава преразхода на време?

Благодаря предварително!

0
Module: Java Advanced
SophYO:
Стигнах до отговор :)
SophYO avatar SophYO 74 Точки

Та, след доста ровене и четене и след като стигнах до глава 10 от книгата на Св. Наков " Въведение в програмирането с Java", установих, че това е може би най- грешно взетото решение за решаване на тази задача, защото цитирам: " Това решение е интуитивно, кратко и лесно за разбиране. На пръв поглед изглежда, че това е чудесен пример за приложение на рекурсията. Истината е, че това е един от класическите примери за неподходящо използване на рекурсия. ..Ако зададем като стойност n = 100, изчисленията ще отнемат много дълго време (едва ли някой ще изчака толкова дълго, че да види резултата). Причината за това е, че подобна реализация е изключително неефективна. Всяко рекурсивно извикване води след себе си още две, при което дървото на извикванията расте експоненциално..Броят на стъпките за изчисление на fib(100) е от порядъка на 1.6 на степен 100 (това се доказва математически), докато при линейно решение е само 100.  
Проблемът произлиза от това, че се правят напълно излишни изчисления. Много от членовете на редицата се пресмятат многократно."

Ако някой също се е замислил за часовничето е та това е проблема. В книгата може да се открие и чудесно примерно решение на редицата на Фибоначи, което си е почти същото. :)


 

0
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.