hihoCoder 1151 : 骨牌覆盖问题·二 矩阵快速幂

来源:互联网 发布:java线程池简单实现 编辑:程序博客网 时间:2024/06/02 07:28

#1151 : 骨牌覆盖问题·二

时间限制:10000ms
单点时限:1000ms
内存限制:256MB

描述

上一周我们研究了2xN的骨牌问题,这一周我们不妨加大一下难度,研究一下3xN的骨牌问题?
所以我们的题目是:对于3xN的棋盘,使用1x2的骨牌去覆盖一共有多少种不同的覆盖方法呢?
首先我们可以肯定,奇数长度一定是没有办法覆盖的;对于偶数长度,比如2,4,我们有下面几种覆盖方式:

提示:3xN骨牌覆盖

输入

第1行:1个整数N。表示棋盘长度。1≤N≤100,000,000

输出

第1行:1个整数,表示覆盖方案数 MOD 12357

样例输入
62247088
样例输出
4037
//同1,但是起始的向量和矩阵都变化了,详细可以看hihocoder的说明; //(a, b) x M = (b, a+b)//必须用 long long #include<iostream>#include<stdio.h>#include<string.h>using namespace std;#define M 12357struct matrix{long long map[8][8];}; matrix mat,ans;void init(){int i,j,k;memset(mat.map,0,sizeof(mat.map));for(i=0;i<8;i++)mat.map[i][7-i]=1; mat.map[3][7]=1;mat.map[6][7]=1;mat.map[7][3]=1;mat.map[7][6]=1;for(i=0;i<8;i++)for(j=0;j<8;j++)ans.map[i][j]=(i==j);}matrix mul(matrix a,matrix b){int i,j,k;matrix c;for(i=0;i<8;i++)for(j=0;j<8;j++){c.map[i][j]=0;for(k=0;k<8;k++){c.map[i][j]+=(a.map[i][k]*b.map[k][j])%M;c.map[i][j]%=M;}}return c;}void pow(int n){for(;n;n>>=1){if(n&1)ans=mul(ans,mat);mat=mul(mat,mat);}}int main(){int n; while(scanf("%d",&n)!=EOF){init();pow(n);//linux: printf("%lld",a);//windows: printf("%I64d",a);//cout<<ans.map[1][1]<<endl; 对 //printf("%I64d\n",ans.map[1][1]); 错 printf("%lld\n",ans.map[7][7]);//对 }return 0;}

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 aj5白银前面皱了怎么办 狗吃了巧克力该怎么办 孩子零食吃多了怎么办 上学时月经侧漏怎么办 漏电被电的脚肿怎么办 走路有尿溢出来怎么办 篮球气嘴漏气了怎么办 暗线插座盒坏了怎么办 焊过电焊眼睛疼怎么办 烧电焊后眼睛痛怎么办? 焊完电焊眼睛疼怎么办 烧电焊后眼睛痛怎么办 用电焊后眼睛痛怎么办 看电焊后眼睛痛怎么办 眼睛焊电焊很痛怎么办 电焊没带眼睛痛怎么办 有东西进眼睛了怎么办 眼睛有东西磨眼怎么办 怀孕了眼睛肿疼怎么办 眼睛疼又红血丝怎么办 用眼过度眼睛疼怎么办 眼睛玩手机视力下降怎么办 看手机眼睛疼该怎么办 眼睛眨一下就痛怎么办 着火了怎么办教案详案 汽车尾灯磕破了怎么办 后尾灯灯罩裂了怎么办 七氟丙烷喷伤了怎么办 冒险岛2fps低怎么办 虐杀原形2很卡怎么办 玩虐杀原形2卡怎么办 虐杀原形2闪退怎么办 电脑显示不出u盘怎么办 电脑不显示u盘怎么办 u盘在电脑不显示怎么办 笔记本不识别u盘怎么办 u盘突然识别不了怎么办 xp电脑读不出u盘怎么办 电脑无法读取u盘怎么办 win7电脑不读u盘怎么办 电脑识别不出u盘怎么办