大数加法,套用模板即可。题目的最大输入为 10^100,有 101 位。先初步对 Fibonacci 数打表,发现第 500 个 Fibonacci 数有 105 位,所以对前 500 个 Fibonacci 数打表,然后依次判断每个 Fibonacci 数是否在 [a,b] 范围内,输出总数量。(注意题目中的 Fibonacci 数列开头只有一个 1,即 1,2,3,5,……)
#include <iostream>
#include <string>
using namespace std;
const int MAXN = 110;
int fib[500][MAXN]; //前500个Fibonacci数
int a[MAXN], b[MAXN]; //大数a,大数b
//大数加法,对前500个Fibonacci数打表
void init()
{
fib[0][0] = 1; fib[0][1] = 1; //每行第0位为该行数字的位数
fib[1][0] = 1; fib[1][1] = 1;
for (int i = 2; i < 500; i++) //依次计算每个Fibonacci数
{
int carry = 0; //进位
for (int j = 1; j <= fib[i - 1][0]; j++)
{
fib[i][j] = fib[i - 1][j] + fib[i - 2][j] + carry;
carry = fib[i][j] / 10;
fib[i][j] %= 10;
}
fib[i][0] = fib[i - 1][0];
while (carry > 0)
{
fib[i][++fib[i][0]] = carry % 10;
carry /= 10;
}
}
}
int main()
{
init();
string s1, s2;
while (cin >> s1 >> s2)
{
if (s1 == "0" && s2 == "0")
break;
int len1 = s1.size();
int len2 = s2.size();
a[0] = len1;
b[0] = len2;
for (int i = len1; i > 0; i--)
a[i] = s1[len1 - i] - '0';
for (int i = len2; i > 0; i--)
b[i] = s2[len2 - i] - '0';
int total = 0; //范围内的Fibonacci数的数量
bool flagA, flagB; //当前Fibonacci数是否大于等于a,是否小于等于b
for (int i = 1; i < 500; i++) //依次判断每个Fibonacci数
{
if (fib[i][0] < a[0]) //当前Fibonacci数位数小于a的位数
continue;
else if (fib[i][0] > b[0]) //当前Fibonacci数位数大于b的位数
break;
flagA = true; flagB = true;
if (fib[i][0] == a[0])
{
for (int j = a[0]; j > 0; j--)
{
if (fib[i][j] > a[j])
break;
else if (fib[i][j] < a[j])
{
flagA = false;
break;
}
}
}
if (fib[i][0] == b[0])
{
for (int j = b[0]; j > 0; j--)
{
if (fib[i][j] < b[j])
break;
else if (fib[i][j] > b[j])
{
flagB = false;
break;
}
}
}
if (flagA == true && flagB == true)
++total;
}
cout << total << endl;
}
return 0;
}
继续加油。