NYOJ-301递推求值
递推求值
时间限制:1000 ms | 内存限制:65535 KB
难度:4
- 描述
-
给你一个递推公式:
f(x)=a*f(x-2)+b*f(x-1)+c
并给你f(1),f(2)的值,请求出f(n)的值,由于f(n)的值可能过大,求出f(n)对1000007取模后的值。
注意:-1对3取模后等于2
- 输入
- 第一行是一个整数T,表示测试数据的组数(T<=10000)
随后每行有六个整数,分别表示f(1),f(2),a,b,c,n的值。
其中0<=f(1),f(2)<100,-100<=a,b,c<=100,1<=n<=100000000 (10^9) - 输出
- 输出f(n)对1000007取模后的值
- 样例输入
-
2 1 1 1 1 0 5 1 1 -1 -10 -100 3
- 样例输出
-
5 999896
//B^(n-2)采用矩阵快速幂计算#include <stdio.h> #include <string.h> #define N 3 #define mod 1000007 #define ll long long struct Matrix{ ll mat[N][N];//乘积时(可能接近mod^2)超出int, }; struct Matrix mul(struct Matrix a,struct Matrix b) { int i,j,k; struct Matrix res; for(i=0;i<N;i++) { for(j=0;j<N;j++) { res.mat[i][j] = 0; for(k=0;k<N;k++) { res.mat[i][j] += a.mat[i][k]*b.mat[k][j]; res.mat[i][j] %= mod;//必须每次取余 } } } return res; } struct Matrix mul_matrix(struct Matrix b,int n) { struct Matrix res = { 1,0,0, 0,1,0, 0,0,1 };//单位阵 while(n) { if(n&1) res = mul(res,b); n >>= 1; b = mul(b,b); } return res; } int main() { int T,f[2],a,b,c,n; struct Matrix tmp,res; struct Matrix tmp_matrix = {//中间矩阵 0,0,0,//每组测试将此三处的值更新为b,a,c 1,0,0, 0,0,1 }; memset(tmp.mat,0,sizeof(tmp.mat));//tmp值只有(0,0),(1,0)需要填入f(2),f(1)的值,其余不变 tmp.mat[2][0] = 1; scanf("%d",&T); while(T--) { scanf("%d%d%d%d%d%d",&f[0],&f[1],&a,&b,&c,&n); if(n == 1 || n == 2) printf("%d\n",(f[n-1]+mod)%mod);//注意对负值的处理 else{ tmp_matrix.mat[0][0] = b; tmp_matrix.mat[0][1] = a; tmp_matrix.mat[0][2] = c; tmp.mat[0][0] = f[1]; tmp.mat[1][0] = f[0]; //实际上最终我们只需进行矩阵和向量(f(2),f(1),1)'的运算,但是因为在进行矩阵快速幂时我们已经定义了矩阵乘积 //所以不妨借用,最后取(0,0)的值即可 res = mul(mul_matrix(tmp_matrix,n-2),tmp); printf("%lld\n",(res.mat[0][0]+mod)%mod); } } return 0; }
参照:http://blog.csdn.net/lyhvoyage/article/details/22926265
2017-02-28
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 对象命名为何需要避免'-er'和'-or'后缀
· SQL Server如何跟踪自动统计信息更新?
· AI与.NET技术实操系列:使用Catalyst进行自然语言处理
· 分享一个我遇到过的“量子力学”级别的BUG。
· Linux系列:如何调试 malloc 的底层源码
· JDK 24 发布,新特性解读!
· C# 中比较实用的关键字,基础高频面试题!
· .NET 10 Preview 2 增强了 Blazor 和.NET MAUI
· Ollama系列05:Ollama API 使用指南
· 为什么AI教师难以实现