2013-04-17 14:34:39 +08:00

53 lines
1.0 KiB
C++

/** The Fibonacci sequence is defined by the recurrence relation:
Fn = Fn1 + Fn2, where F1 = 1 and F2 = 1.
Hence the first 12 terms will be:
F1 = 1
F2 = 1
F3 = 2
F4 = 3
F5 = 5
F6 = 8
F7 = 13
F8 = 21
F9 = 34
F10 = 55
F11 = 89
F12 = 144
The 12th term, F12, is the first term to contain three digits.
What is the first term in the Fibonacci sequence to contain 1000 digits? */
#include "0.hpp"
#include "lib/lint.cpp"
void fib_matrix(unsigned int maxnum);
int main()
{
unsigned int max;
cin >> max;
//for(int i = 1; i <= max; i++) cout << fib_recursive(i) << endl;
fib_matrix(max);
return 0;
}
void fib_matrix(unsigned int maxnum)
{
string first = "1";
lint fib[2];
fib[0] = first;
fib[1] = first;
//for(int i = 1; i <= maxnum; i++) {
int i = 1;
while(1) {
//cout << fib[i % 2].getd() << endl;
if(fib[i % 2].getd().size() >= maxnum) break;
if(i >= 2) fib[(i + 1) % 2] = fib[(i + 1) % 2] + fib[i % 2];
i++;
}
//cout << fib[maxnum % 2].getd() << endl;
cout << i << endl;
}