日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

poj 3233 Matrix Power Series

發(fā)布時間:2024/2/28 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 poj 3233 Matrix Power Series 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

最近一直在做矩陣的題目,這算是一道簡單題目吧。

建立一個矩陣的結(jié)構(gòu)體,便于賦值和返回值。

S?=?A?+?A2?+?A3?+ … +?Ak

? ??如果 S=A+A2?+?A3?+A4 ? S= (A?+?A2)*(E+A2) ?所以只需要 二分操作就可以了

? ?再輔助以 快速冪,矩陣乘法,矩陣加法就可以了

#include<cstdio> #include<cstring> #include<iostream> using namespace std; struct matrix{int f[40][40]; }; int n,m; matrix pow(matrix a,matrix b) {int i,j,k;matrix c;memset(c.f,0,sizeof(c.f));for(i=0;i<n;i++)for(j=0;j<n;j++)for(k=0;k<n;k++)c.f[i][j]=(c.f[i][j]+a.f[i][k]*b.f[k][j])%m;return c; } matrix quick_pow(matrix a,int k) {matrix s;memset(s.f,0,sizeof(s.f));int i;for(i=0;i<n;i++) s.f[i][i]=1;while(k){if(k&1)s=pow(s,a);a=pow(a,a);k=k>>1;}return s; } matrix add(matrix a,matrix b) {int i,j;for(i=0;i<n;i++)for(j=0;j<n;j++)a.f[i][j]=(a.f[i][j]+b.f[i][j])%m;return a; } matrix solve(matrix A,int k) {matrix E;memset(E.f,0,sizeof(E.f));int i;for(i=0;i<n;i++) E.f[i][i]=1;if(k==1) return A;else if(k&1)return add(solve(A,k-1),quick_pow(A,k));elsereturn pow(solve(A,k/2),(add(quick_pow(A,k/2),E))); } int main() {int i,j,k;matrix prematrix;scanf("%d%d%d",&n,&k,&m);for(i=0;i<n;i++)for(j=0;j<n;j++)scanf("%d",&prematrix.f[i][j]);matrix ans=solve(prematrix,k);for(i=0;i<n;i++){for(j=0;j<n;j++){if(j==0) printf("%d",ans.f[i][j]%m);else printf(" %d",ans.f[i][j]%m);}printf("\n");} }
超強干貨來襲 云風專訪:近40年碼齡,通宵達旦的技術(shù)人生

總結(jié)

以上是生活随笔為你收集整理的poj 3233 Matrix Power Series的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。