#include <iostream>
#include <cstdio>
int A[220][220],B[220][220],C[220][220];
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int n,s,m,w;
scanf("%d %d",&n,&s);
for(int i = 0; i < n; i++)
for(int j = 0; j < s ; j++)
scanf("%d",&A[i][j]);
scanf("%d %d",&w , &m);
for(int p = 0; p < w; p++)
for(int q = 0; q < m; q++)
scanf("%d",&B[p][q]);
if(s == w)
printf("YES\n");
else
{
printf("NO\n");
continue;
}
int i , j ,k ;
for(i = 0; i < n; i++)
{
for(j = 0; j < m; j++)
{
C[i][j] = 0;
}
}
for(i = 0; i < n; i++)
{
for(k = 0; k < s; k++)
{
if(A[i][k] == 0)
continue;
for(j = 0; j < m; j++)
{
C[i][j] = (C[i][j] + A[i][k] * B[k][j]);
}
}
}
for(int i = 0; i < n; i++)
for(int j = 0; j < m; j++)
{
if( j == m-1)
printf("%d\n",C[i][j]);
else
printf("%d ",C[i][j]);
}
}
return 0;
}