当前位置: 首页 > news >正文

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

转载于:https://www.cnblogs.com/520xiuge/p/5469577.html

相关文章:

  • HDOJ(HDU) 2502 月之数(进制)
  • 那些年我们用过的显示性能指标
  • HDU5620 KK's Steel(C语言版)
  • 如何取消系统关机
  • 自动获取IP,然后设置为静态IP
  • ugui中随机更换图片的方法:一
  • 随屏幕滚动的带缓冲效果的右下角广告
  • HTML5上传文件显示进度
  • NSDate-日期类nbsp;OC——第七天(1)
  • UIController子类控件nbsp;UI_06
  • 编程珠玑--旋转算法
  • 基本排序算法二
  • HDU - 1455 Sticks(深搜+剪枝)
  • perl 递归两例
  • Tomcat学习总结(3)——Tomcat优化详细教程
  • Google 是如何开发 Web 框架的
  • Angular数据绑定机制
  • java8-模拟hadoop
  • JS创建对象模式及其对象原型链探究(一):Object模式
  • 阿里云应用高可用服务公测发布
  • 给自己的博客网站加上酷炫的初音未来音乐游戏?
  • 互联网大裁员:Java程序员失工作,焉知不能进ali?
  • 类orAPI - 收藏集 - 掘金
  • 前端攻城师
  • 前言-如何学习区块链
  • 区块链分支循环
  • 使用docker-compose进行多节点部署
  • 微服务入门【系列视频课程】
  • 协程
  • const的用法,特别是用在函数前面与后面的区别
  • ionic异常记录
  • 从如何停掉 Promise 链说起
  • ​LeetCode解法汇总518. 零钱兑换 II
  • # Java NIO(一)FileChannel
  • #调用传感器数据_Flink使用函数之监控传感器温度上升提醒
  • #图像处理
  • (10)ATF MMU转换表
  • (4)通过调用hadoop的java api实现本地文件上传到hadoop文件系统上
  • (JSP)EL——优化登录界面,获取对象,获取数据
  • (pt可视化)利用torch的make_grid进行张量可视化
  • (附源码)springboot 智能停车场系统 毕业设计065415
  • (蓝桥杯每日一题)love
  • (力扣记录)235. 二叉搜索树的最近公共祖先
  • (十一)手动添加用户和文件的特殊权限
  • (转)Unity3DUnity3D在android下调试
  • (转载)CentOS查看系统信息|CentOS查看命令
  • (转载)微软数据挖掘算法:Microsoft 时序算法(5)
  • .Net - 类的介绍
  • .net core 6 redis操作类
  • .NET设计模式(11):组合模式(Composite Pattern)
  • .NET序列化 serializable,反序列化
  • .w文件怎么转成html文件,使用pandoc进行Word与Markdown文件转化
  • @31省区市高考时间表来了,祝考试成功
  • @Bean注解详解
  • @开发者,一文搞懂什么是 C# 计时器!