2020-05-29 03:17:53 +08:00
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @brief This Programme returns the Nth fibonacci as a string.
|
|
|
|
*
|
|
|
|
* The method used is manual addition with carry and placing it in a string
|
|
|
|
* which is called string addition This makes it have no bounds or limits
|
|
|
|
*
|
|
|
|
* @see fibonacci_large.cpp, fibonacci_fast.cpp, fibonacci.cpp
|
|
|
|
*/
|
2017-12-26 20:16:50 +08:00
|
|
|
|
|
|
|
#include <iostream>
|
2020-05-29 03:17:53 +08:00
|
|
|
#ifdef _MSC_VER
|
|
|
|
#include <string> // use this for MS Visual C
|
|
|
|
#else
|
|
|
|
#include <cstring> // otherwise
|
|
|
|
#endif
|
2017-12-26 20:16:50 +08:00
|
|
|
|
2020-05-29 03:17:53 +08:00
|
|
|
/**
|
|
|
|
* function to add two string numbers
|
|
|
|
* \param [in] a first number in string to add
|
|
|
|
* \param [in] b second number in string to add
|
|
|
|
* \returns sum as a std::string
|
|
|
|
*/
|
2020-05-30 07:26:30 +08:00
|
|
|
std::string add(std::string a, std::string b)
|
|
|
|
{
|
2020-05-29 03:17:53 +08:00
|
|
|
std::string temp = "";
|
2018-03-28 00:51:25 +08:00
|
|
|
|
|
|
|
// carry flag
|
|
|
|
int carry = 0;
|
|
|
|
|
|
|
|
// fills up with zeros
|
2020-05-30 07:26:30 +08:00
|
|
|
while (a.length() < b.length())
|
|
|
|
{
|
2017-12-26 20:16:50 +08:00
|
|
|
a = "0" + a;
|
|
|
|
}
|
2018-03-28 00:51:25 +08:00
|
|
|
|
|
|
|
// fills up with zeros
|
2020-05-30 07:26:30 +08:00
|
|
|
while (b.length() < a.length())
|
|
|
|
{
|
2017-12-26 20:16:50 +08:00
|
|
|
b = "0" + b;
|
|
|
|
}
|
2018-03-28 00:51:25 +08:00
|
|
|
|
|
|
|
// adds the numbers a and b
|
2020-05-30 07:26:30 +08:00
|
|
|
for (int i = a.length() - 1; i >= 0; i--)
|
|
|
|
{
|
2020-05-29 03:59:28 +08:00
|
|
|
char val = static_cast<char>(((a[i] - 48) + (b[i] - 48)) + 48 + carry);
|
2020-05-30 07:26:30 +08:00
|
|
|
if (val > 57)
|
|
|
|
{
|
2017-12-26 20:16:50 +08:00
|
|
|
carry = 1;
|
|
|
|
val -= 10;
|
2020-05-30 07:26:30 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-12-26 20:16:50 +08:00
|
|
|
carry = 0;
|
|
|
|
}
|
|
|
|
temp = val + temp;
|
|
|
|
}
|
2018-03-28 00:51:25 +08:00
|
|
|
|
|
|
|
// processes the carry flag
|
2020-05-30 07:26:30 +08:00
|
|
|
if (carry == 1)
|
|
|
|
{
|
2017-12-26 20:16:50 +08:00
|
|
|
temp = "1" + temp;
|
|
|
|
}
|
2018-03-28 00:51:25 +08:00
|
|
|
|
|
|
|
// removes leading zeros.
|
2020-05-30 07:26:30 +08:00
|
|
|
while (temp[0] == '0' && temp.length() > 1)
|
|
|
|
{
|
2017-12-26 20:16:50 +08:00
|
|
|
temp = temp.substr(1);
|
|
|
|
}
|
2018-03-28 00:51:25 +08:00
|
|
|
|
2017-12-26 20:16:50 +08:00
|
|
|
return temp;
|
|
|
|
}
|
|
|
|
|
2020-05-29 03:17:53 +08:00
|
|
|
/** Fibonacci iterator
|
|
|
|
* \param [in] n n^th Fibonacci number
|
|
|
|
*/
|
2020-05-30 07:26:30 +08:00
|
|
|
void fib_Accurate(uint64_t n)
|
|
|
|
{
|
2020-05-29 03:17:53 +08:00
|
|
|
std::string tmp = "";
|
|
|
|
std::string fibMinus1 = "1";
|
|
|
|
std::string fibMinus2 = "0";
|
2020-05-30 07:26:30 +08:00
|
|
|
for (uint64_t i = 0; i < n; i++)
|
|
|
|
{
|
2018-03-28 00:51:25 +08:00
|
|
|
tmp = add(fibMinus1, fibMinus2);
|
|
|
|
fibMinus2 = fibMinus1;
|
|
|
|
fibMinus1 = tmp;
|
|
|
|
}
|
2020-05-29 03:17:53 +08:00
|
|
|
std::cout << fibMinus2;
|
2017-12-26 20:16:50 +08:00
|
|
|
}
|
|
|
|
|
2020-05-29 03:17:53 +08:00
|
|
|
/** main function */
|
2020-05-30 07:26:30 +08:00
|
|
|
int main()
|
|
|
|
{
|
2017-12-26 20:16:50 +08:00
|
|
|
int n;
|
2020-05-29 03:17:53 +08:00
|
|
|
std::cout << "Enter whatever number N you want to find the fibonacci of\n";
|
|
|
|
std::cin >> n;
|
|
|
|
std::cout << n << " th Fibonacci is \n";
|
2018-03-28 00:51:25 +08:00
|
|
|
fib_Accurate(n);
|
|
|
|
|
2018-10-16 20:46:37 +08:00
|
|
|
return 0;
|
2017-12-26 20:16:50 +08:00
|
|
|
}
|