题解 | 递推数列

递推数列

https://www.nowcoder.com/practice/d0e751eac618463bb6ac447369e4aa25

因为运算次数可能比较多,使用递归函数可能会导致栈溢出进而促成超时,故而还是使用一个数组作为存储递归值的单位从而降低耗时。本题直接将递归规律写出,所以并不难。

#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;
}
牛客题库练习笔记 文章被收录于专栏

有的时候心血来潮会来做题。做题就会有笔记。

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务