poj 2440 矩阵乘法

#include<stdio.h>
#include<iostream>
#include<string.h>
#include<math.h>
using namespace std;
const int M=2005;
const int N=4;
int L;
struct Mat
{
	int mat[N][N],n,m;//n行m列矩阵
	void init(int r,int c)
	{
		n=r;m=c;
	}
	void init_e()
	{
		for(int i=0;i<n;i++)
			for(int j=0;j<m;j++)
				mat[i][j]=(i==j);
	}
};

Mat Mul(Mat a,Mat b)
{
	Mat ret;
	ret.init(a.n,b.m);
	memset(ret.mat,0,sizeof(ret.mat));
	for(int i=0;i<a.n;i++)
		for(int j=0;j<b.m;j++)
			for(int k=0;k<b.n;k++)
			{
				ret.mat[i][j]+=a.mat[i][k]*b.mat[k][j];
				if(ret.mat[i][j]>M) ret.mat[i][j]%=M;
			}
	return ret;
}
Mat exp(Mat a,int k)
{
	Mat ret=a,tmp=a;
	ret.init_e();
	for( ;k;k>>=1)
	{
		if(k&1)
		{
			ret=Mul(ret,tmp);
		}
		tmp=Mul(tmp,tmp);
	}
	return ret;
}
int main()
{
//    freopen("test.txt","r",stdin);
    Mat a; a.init(2,2);
    a.mat[0][0]=0;a.mat[0][1]=1;
    a.mat[1][0]=a.mat[1][1]=1;
    while(scanf("%d",&L)!=EOF)
    {
        Mat ret;
        ret=exp(a,L/2);
        int ans,detal;
        int t1=ret.mat[0][0]+2*ret.mat[1][0];
        int t2=ret.mat[0][1]+2*ret.mat[1][1];

        if(L%4==1) detal=-1;
        else if(L%4==3) detal=1;
        if(L%2) ans=(t2*t2-t1*t1+detal)%M;
        else ans=(t1*t1)%M;
        if(ans<0) ans+=M;
        printf("%d\n",ans);
    }
    return 0;

}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值