题解 | #递推数列#

递推数列

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

//此题一看就大概知道有两种限制,递归的时间复杂度和整数的表示范围,由于an=p*a(n-1) + q*a(n-2)
//可知,an对10000取余的结果只由a(n-1),a(n-2)中不超过10000的部分决定,所以每次ai算完后对10000取余即可
#include "stdio.h"
using namespace std;
int a[10000]={0};

int main(){
    int a0,a1,p,q,k;
    scanf("%d%d%d%d%d",&a0,&a1,&p,&q,&k);
    a[0]=a0;
    a[1]=a1;
    for (int i = 2; i <= k; ++i) {
        a[i]=a[i-1]*p+a[i-2]*q;
        if(a[i]>10000)
            a[i]=a[i]%10000;
    }
    printf("%d",a[k]);
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-09 12:20
点赞 评论 收藏
分享
牛客83700679...:简历抄别人的,然后再投,有反馈就是简历不行,没反馈就是学历不行,多投多改只要技术不差机会总会有的
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-10 11:45
你不要过来啊啊啊啊啊啊啊
码农索隆:对面:“今天你不面也得面”
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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