const int MAXN=1e5+5,mod=1e9+7;
struct BIT{
#define lowbit(x) ((x)&(-x))
int c[MAXN];
void add(int pos,int v){
while(pos
#include
using namespace std;
const int N=505,mod=998244353;
int A[N][N],B[N][2*N],C[N][N],D[N][N],E[N][N],F[N][N];
int qpow(int x,int y){
int ret=1;
for(;y;x=1ll*x*x%mod,y>>=1)
if(y&1) ret=1ll*ret*x%mod;
return ret;
}
void Get_Inverse_1(int n,int& det){
det=1;
memset(B,0,sizeof(B));
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) B[i][j]=A[i][j];
for(int i=1;i<=n;i++) B[i][i+n]=1;
int times=0;
for(int i=1;i=1;i--){
int temp=B[i][i];
temp=qpow(temp,mod-2);
B[i][i]=1;
for(int k=n+1;k<=2*n;k++) B[i][k]=1ll*B[i][k]*temp%mod;
int temp2=qpow(B[i][i],mod-2);
for(int j=i-1;j>=1;j--){
int m=1ll*B[j][i]*temp2;
for(int k=n+1;k<=2*n;k++){
B[j][k]=(1ll*B[j][k]-1ll*m*B[i][k]%mod+mod)%mod;
}
}
}
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) C[i][j]=B[i][j+n];
}
int C2[N],C3[N];
void Get_Inverse_2(int n,int x,int y,int delta){
int deno=(1+1ll*C[y][x]*delta%mod)%mod;
deno=qpow(deno,mod-2);
for(int i=1;i<=n;i++) C2[i]=C[i][x],C3[i]=C[y][i];
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)
C[i][j]=(1ll*C[i][j]-1ll*C2[i]*delta%mod*C3[j]%mod*deno%mod+mod)%mod;
}
}
int main(){
int n,q;
scanf("%d%d",&n,&q);
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) scanf("%d",&A[i][j]);
int det;
Get_Inverse_1(n,det);
while(q--){
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
int before=A[x][y];
A[x][y]=z;
int ans=0;
for(int j=1;j<=n;j++){
ans=(1ll*ans+1ll*A[x][j]*C[j][x]%mod*det%mod)%mod;
}
printf("%d\n",ans);
det=ans;
int delta=(z-before+mod)%mod;
Get_Inverse_2(n,x,y,delta);
}
return 0;
}
const int MAXN=105;
int dp[MAXN][MAXN][MAXN][2],mod;
void add(int &x,int y){
x+=y;
if(x>=mod)x-=mod;
}
int main()
{
int n=read_int();
mod=read_int();
dp[1][1][2][1]=1;
_for(i,1,n)_rep(j,1,i)_rep(k,1,j+1)_for(t,0,2){
_rep(p,1,i+1){
if(p>j)
add(dp[i+1][p][k=p],dp[i][j][k][t]);
else if(p==j){
if(t){
if(j