#include <iostream>
#include <vector>
using namespace std;
int main() {
int n; // n为矩阵阶数
while(cin>>n) {
int x, y, i, j; // 用于循环控制
vector< vector<int> > vec1(n, vector<int>(n));
vector< vector<int> > vec2(n, vector<int>(n));
// 向动态数组中存入数据
for(x=0; x<n; x++) {
for(y=0; y<n; y++) {
int mid; // 中间变量,用于向vec1中存入数据
cin>>mid;
vec1[x][y] = mid;
}
}
for(x=0; x<n; x++) {
for(y=0; y<n; y++) {
int mid; // 中间变量,用于向vec2中存入数据
cin>>mid;
vec2[x][y] = mid;
}
}
int flag = 0; // 用于判定全部元素是否符合旋转角度,是flag=1,否flag=0
int angle = -1; // 记录旋转角度
// 判断旋转角度是否为0
for(i=0; i<n; i++) {
for(j=0; j<n; j++) {
if(vec1[i][j] == vec2[i][j]) {
flag = 1;
continue;
}
else {
flag = 0;
break;
}
}
if(flag == 1) {
continue;
}
else {
break;
}
}
if(flag == 1) {
angle = 0;
cout<<angle<<endl;
continue;
}
else {
angle = -1;
}
// 判断旋转角度是否为90
for(i=0; i<n; i++) {
for(j=0; j<n; j++) {
if(vec1[i][j] == vec2[j][n-1-i]) {
flag = 1;
continue;
}
else {
flag = 0;
break;
}
}
if(flag == 1) {
continue;
}
else {
break;
}
}
if(flag == 1) {
angle = 90;
cout<<angle<<endl;
continue;
}
else {
angle = -1;
}
// 判断旋转角度是否为180
for(i=0; i<n; i++) {
for(j=0; j<n; j++) {
if(vec1[i][j] == vec2[n-1-i][n-1-j]) {
flag = 1;
continue;
}
else {
flag = 0;
break;
}
}
if(flag == 1) {
continue;
}
else {
break;
}
}
if(flag == 1) {
angle = 180;
cout<<angle<<endl;
continue;
}
else {
angle = -1;
}
// 判断旋转角度是否为279
for(i=0; i<n; i++) {
for(j=0; j<n; j++) {
if(vec1[i][j] == vec2[n-1-j][i]) {
flag = 1;
continue;
}
else {
flag = 0;
break;
}
}
if(flag == 1) {
continue;
}
else {
break;
}
}
if(flag == 1) {
angle = 270;
cout<<angle<<endl;
continue;
}
else {
angle = -1;
}
// 若以上角度都不符合
if(angle == -1) {
cout<<angle<<endl;
continue;
}
}
return 0;
}