Cod sursa(job #1451353)

Utilizator rangerChihai Mihai ranger Data 16 iunie 2015 20:42:43
Problema Al k-lea termen Fibonacci Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.45 kb
#include<fstream>
#include<map>
using namespace std;
#define ll long long
#define mod 666013
ll n;
map <ll,ll>  Fib;

ifstream cin("kfib.in");
ofstream cout("kfib.out");

ll fib(ll n)
{
     if (n<2) return 1;
     if (Fib.find(n)!=Fib.end()) return Fib[n];
     Fib[n] = ( fib((n+1)/2)*fib(n/2) + fib((n-1)/2)*fib((n-2)/2) )%mod;
     return Fib[n];
 }

int main()
{
	cin>>n;
	if (!n) cout<<0;
	else cout<<fib(n-1);
	return 0;
}