#include<iostream>
#include<string.h>
using namespace std;
int n, m, mod;
struct mat{
int a[65][65];
mat(){
memset(a, 0, sizeof(a));
for(int i = 0; i < 2*n; i++) a[i][i] = 1;
}
mat operator * (const mat& b){
mat c;
for(int i = 0; i < 2*n; i++)
for(int j = 0; j < 2*n; j++){
c.a[i][j] = 0;
for(int k = 0; k < 2*n; k++)
c.a[i][j] = (c.a[i][j] + a[i][k] * b.a[k][j])%mod;
}
return c;
}
mat pow(int N){
mat ans, b = *this;
while(N){
if(N%2) ans = ans * b;
b = b * b;
N /= 2;
}
return ans;
}
};
int main(){
cin >> n >> m >> mod;
mat a, b;
for(int i = 0; i < n; i++) b.a[i][i+n] = 1;
memset(a.a, 0, sizeof(a.a));
for(int i = 0; i < n; i++)
for(int j = 0; j < n; j++){
cin >> a.a[i+n][j];
b.a[i][j] = a.a[i+n][j];
}
mat c = b.pow(m);
mat ans;
for(int i = 0; i < 2*n; i++)
for(int j = 0; j < n; j++){
ans.a[i][j] = 0;
for(int k = 0; k < 2*n; k++)
ans.a[i][j] = (ans.a[i][j] + c.a[i][k] * a.a[k][j])%mod;
}
for(int i = 0; i < n; i++)
for(int j = 0; j < n; j++){
cout << ans.a[i][j];
if(j == n-1) cout << endl;
else cout << " ";
}
return 0;
}
POJ3233
最新推荐文章于 2020-01-21 15:40:01 发布