题解 | 递推数列

递推数列

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

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

全部评论

相关推荐

水墨不写bug:疑似没有上过大学
点赞 评论 收藏
分享
05-09 12:23
已编辑
华南理工大学 Java
野猪不是猪🐗:给他装的,双九+有实习的能看的上这种厂我直接吃⑨✌们拿它练练面试愣是给他整出幻觉了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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