因为运算次数可能比较多,使用递归函数可能会导致栈溢出进而促成超时,故而还是使用一个数组作为存储递归值的单位从而降低耗时。本题直接将递归规律写出,所以并不难。
#include <bits/stdc++.h>
#define _CRT_SECURE_NO_WARNINGS
int main()
{
int a0, a1, p, q, k;
std::cin >> a0 >> a1 >> p >> q >> k;
std::vector<int> a(k + 1);
a[0] = a0 % 10000;
a[1] = a1 % 10000;
for (int i = 2; i < k + 1; i++)
{
a[i] = p * a[i - 1] % 10000 + q * a[i - 2] % 10000;
a[i] %= 10000;
}
std::cout << a.back() << std::endl;
return 0;
}