Série de Fibonacci
Publicado por Oberlan C. Romão (última atualização em 29/05/2010)
[ Hits: 6.263 ]
Homepage: http://twitter.com/oberlan
Um dos grandes problemas de quem participa de algum campeonato de programação e tem que fazer o programa gerar respostas rápidas é fazer a série de Fibonacci de forma eficiente. Pensando nisso resolvi apresentar uma solução.
O programa usa programação dinâmica, ou seja, ele vai armazenado as soluções que são encontradas, o que acelera o calculo da série.
#include <iostream>
#define ll long long
#define MAX 200
using namespace std;
ll tab[MAX];
void ini_fibo(){
for(int i=0; i<MAX; ++i)
tab[i] = -1;
tab[0] = 0;
tab[1] = 1;
}
ll fibo(ll n){
if(tab[n] != -1) return tab[n];
ll i = 2;
for(; i<=n; ++i)
if(tab[i] == -1) break;
for(; i<=n; ++i)
tab[i] = tab[i-1] + tab[i-2];
return tab[n];
}
int main(){
ll n;
cin >> n;
ini_fibo();
while (n){
cout << "Fibonacci(" << n << ") = " << fibo(n) << endl;
cin >> n;
}
return 0;
}
Decimal ( 8 bits ) para binário
Nenhum comentário foi encontrado.
IA Turbina o Desktop Linux enquanto distros renovam forças
Como extrair chaves TOTP 2FA a partir de QRCODE (Google Authenticator)
Linux em 2025: Segurança prática para o usuário
Desktop Linux em alta: novos apps, distros e privacidade marcam o sábado
IA chega ao desktop e impulsiona produtividade no mundo Linux
Atualizando o Fedora 42 para 43
Como saber se o seu e-mail já teve a senha vazada?
Como descobrir se a sua senha já foi vazada na internet?
Secure boot, artigo interessante, nada técnico. (1)
Preciso recuperar videos *.mp4 corrompidos (1)
\Boot sem espaço em disco (Fedora KDE Plasma 42) (6)









