按部就班,超级简单,虽然不是一次过的。。。错在那个long long数据问题还是要注意。。也不知道要怎么注意;还是说题目吧。。。

思路看main函数

其他函数功能也是非常有用!代码比较丑。。。见谅

#include <stdio.h>

#include <iostream>

#include <sstream>

#include <string.h>

#include <math.h>

#include<stdlib.h>

#include <queue>

#include <set>

#include <algorithm>

using namespace std;

long long mod;

struct asd{

    long long a[4][4];

};

asd ak;                   //代表A的k次

asd mul(asd x,asd y)      //矩阵乘法

{

    int i,j,k;

    asd ans;

    for(i=0;i<2;i++)

    {

        for(j=0;j<2;j++)

        {

            ans.a[i][j]=0;

            for(k=0;k<2;k++)

            {

                ans.a[i][j]+=(x.a[i][k]*y.a[k][j])%mod;

                ans.a[i][j]%=mod;

            }

        }

    }

    return ans;

}

asd add(asd x,asd y)   //矩阵加法

{

    int i,j,k;

    asd ans;

    for(i=0;i<2;i++)

    {

        for(j=0;j<2;j++)

        {

            ans.a[i][j]=(x.a[i][j]+y.a[i][j])%mod;

        }

    }

    return ans;

}

asd quick(asd y,long long g)   //快速幂

{

    asd x;

    int i,k,j;

    for(i=0;i<2;i++)

    {

        for(j=0;j<2;j++)

        {

            if(i==j)

                x.a[i][i]=1;

            else

                x.a[i][j]=0;

        }

    }

    while(g)

    {

        if(g%2==1)

            x=mul(x,y);

        y=mul(y,y);

        g/=2;

    }

    return x;

}

asd slove(long long z)    //计算S(n);S(n)代表A的1次加到A的n次;

{

    if(z==1)

        return ak;

    asd ans=slove(z/2);

    asd cur;

    if(z%2==1)

    {

        cur=quick(ak,z/2+1);

        ans=add(ans,mul(ans,cur));

        ans=add(cur,ans);

    }

    else

    {

        cur=quick(ak,z/2);

        ans=add(ans,mul(ans,cur));

    }

    return ans;

}

/*反正就想算数一样,斐波那契的那个矩阵肯定知道(不知道出门左转去学一下矩阵快速幂),假设是A,那么也就是题目要求

就是计算A的0+b次到A的k(n-1)+b次的和,次数的相加拆开就是相乘(不知道去复读初中),那么,把A的b次提出来,A^b(E+A^K+A^2K+...A^(n-1)K)

然后把A^K看作整体就是什么!!!还不知道看main函数代码。。草稿纸上列一列就知道了。。。

*/

int main()

{

    long long k,b,n;

    while(~scanf("%lld%lld%lld%lld",&k,&b,&n,&mod))

    {

        asd fb,ea,ans,y,sk;

        ea.a[0][0]=1;ea.a[0][1]=0;   //单位矩阵

        ea.a[1][0]=0;ea.a[1][1]=1;

        y.a[0][0]=1;y.a[0][1]=1;

        y.a[1][0]=1;y.a[1][1]=0;

        fb=quick(y,b);         //求一个A的b次

        ak=quick(y,k);          //求一个A的K次

        sk=slove(n-1);          //求S(K);

        sk=add(sk,ea);          //把没加的E加上

        ans=mul(sk,fb);         //乘一波

        printf("%lld\n",ans.a[0][1]);    //这里还是看你的线代怎么样了。。

    }

    return 0;

}





hdoj 1588 学好线代与数学的更多相关文章

  1. NYOJ 67 三角形面积(线代,数学)

    三角形面积 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 给你三个点,表示一个三角形的三个顶点,现你的任务是求出该三角形的面积   输入 每行是一组测试数据,有6个 ...

  2. 山东理工大学第七届ACM校赛-飞花的线代 分类: 比赛 2015-06-26 10:29 10人阅读 评论(0) 收藏

    飞花的线代 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 飞花壕的线代一直非常的壕(好),线代考试每次都是全班第一.一次,飞花壕在预习 ...

  3. 线代笔记 #01# 几何水平上的理解 VS. 数值水平上的理解

    源: 线性代数的本质 内容来自字幕. Let me quote without further comment from Dieudonné's "Foundations of Modern ...

  4. numpy--深度学习中的线代基础

    参考自 微信公众号--深度学习世界(http://mp.weixin.qq.com/s?__biz=MzI4MDMwMDM3NA==&mid=2247484616&idx=1& ...

  5. 线代: N阶行列式

    线性变换 将 (x, y) 变成 (2 x + y, x - 3 y) 就叫做线性变换, 这就是矩阵乘法, 用于表示一切线性变换. 几何上看, 把平面上的每个点 (x, y) 都变到 (2 x + y ...

  6. back propogation 的线代描述

    参考资料: 算法部分: standfor, ufldl  : http://ufldl.stanford.edu/wiki/index.php/UFLDL_Tutorial 一文弄懂BP:https: ...

  7. 线代第六章定义&定理整理(持续更新中)

    Chapter 6 6.1 Inner Products and Norms Definition (inner product). Let V be a vector space over F. A ...

  8. 数据挖掘 与 Web开发何去何从

    (0)引子 以下以现实生活中的一个实例引出本博客的探究点.或许类似的情况正发生在你的身边. 小弟工作5年了,近期有点迷茫. 上一份工作在一家比較大的门户站点做web开发和移动互联网数据挖掘(人手比較紧 ...

  9. Python 矩阵(线性代数)

    Python 矩阵(线性代数) 这里有一份新手友好的线性代数笔记,是和深度学习花书配套,还被Ian Goodfellow老师翻了牌. 笔记来自巴黎高等师范学院的博士生Hadrien Jean,是针对& ...

随机推荐

  1. 【BZOJ2795】[Poi2012]A Horrible Poem hash

    [BZOJ2795][Poi2012]A Horrible Poem Description 给出一个由小写英文字母组成的字符串S,再给出q个询问,要求回答S某个子串的最短循环节.如果字符串B是字符串 ...

  2. EasyDarwin开源流媒体服务器提供的TS切片/HLS直播打包库

    EasyHLS  Github:https://github.com/EasyDarwin/EasyHLS EasyHLS是什么? EasyHLS是EasyDarwin开源流媒体社区开发的一款HLS打 ...

  3. 九度OJ 1100:最短路径 (最短路径)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:4185 解决:619 题目描述: N个城市,标号从0到N-1,M条道路,第K条道路(K从0开始)的长度为2^K,求编号为0的城市到其他城市的 ...

  4. 20170316 REUSE_alv_display_lvc 面向对象函数

    **将ALV显示数据更新进输出内表中  DATA: LR_GRID TYPE  REF TO CL_GUI_ALV_GRID.  CALL FUNCTION 'GET_GLOBALS_FROM_SLV ...

  5. 【C++基础学习】成员对象与对象数组

    第一部分 对象成员与对象数组 从一个简单的例子开始说起,首先定义一个Coordinate的类,里面有两个公有的成员变量m_iX和m_iY,分别代表横坐标和纵坐标. 接下来,定义一个对象数组cood和一 ...

  6. 10.19-10.20 test

    2016 10.19-10.20 两天  题目by mzx Day1: T1:loverfinding 题解:hash #include<iostream> #include<cst ...

  7. iOS:UITextField中文输入法输入时对字符长度的限制

      如题的问题,又是个让我抓狂了大半天的问题,还是做个记录,有与类似问题的同学可参考,但不一定对.具体问题还需具体分析.我遇到的需求是这样的:有一个输入框,输入框内输入文字,文字字数限制在20字.   ...

  8. 使用libcurl进行HTTP GET操作

    Working example how to do a GET request with libcurl and save it to a string variable for future use ...

  9. codeforces B. Fox and Cross 解题报告

    题目链接:http://codeforces.com/problemset/problem/389/B 题目意思:给出一个由n行n列组成的board,其中'#'表示的一片地方恰好能画满十字架,画满的意 ...

  10. PHP执行外部命令【转】

    PHP是完全支持外部命令的,但是出于安全考虑,一般很少使用. PHP提供共了3种方法调用外部命令: (1)调用执行外部命令函数(system(),exec(),passthru(),shell_exe ...