0
1
mirror of https://git.sb/baoshuo/OI-codes.git synced 2025-01-23 12:52:00 +00:00

P1205 [USACO1.2]方块转换 Transformations

R36572888
This commit is contained in:
Baoshuo Ren 2020-08-14 13:03:59 +08:00 committed by Baoshuo Ren
parent 39f20723eb
commit 2d5a4841a8
Signed by: baoshuo
GPG Key ID: 70F90A673FB1AB68

116
problem/P1205/P1205.cpp Normal file
View File

@ -0,0 +1,116 @@
// R36572888
#include<bits/stdc++.h>
using namespace std;
struct Matrix {
int map[12][12];
int n;
} from, to;
bool transform1(const Matrix& in) { // Right 90
for (int i = 1; i <= in.n; i++) {
for (int j = 1; j <= in.n; j++) {
if (in.map[i][j] != to.map[j][in.n - i + 1]) {
return 0;
}
}
}
return 1;
}
bool transform2(const Matrix& in) { // Right 180
for (int i = 1; i <= in.n; i++) {
for (int j = 1; j <= in.n; j++) {
if (in.map[i][j] != to.map[in.n - i + 1][in.n - j + 1]) {
return 0;
}
}
}
return 1;
}
bool transform3(const Matrix& in) { // Right 270
for (int i = 1; i <= in.n; i++) {
for (int j = 1; j <= in.n; j++) {
if (in.map[i][j] != to.map[in.n - j + 1][i])
return 0;
}
}
return 1;
}
bool transform4(const Matrix& in) { // Reflect
for (int i = 1; i <= in.n; i++) {
for (int j = 1; j <= in.n; j++) {
if (in.map[i][j] != to.map[i][in.n - j + 1])
return 0;
}
}
return 1;
}
bool transform5(const Matrix& in) {
Matrix tmp;
tmp.n = in.n;
for (int i = 1; i <= in.n; i++) {
for (int j = 1; j <= in.n; j++) {
tmp.map[i][j] = in.map[i][in.n - j + 1];
}
}
return (transform1(tmp) || transform2(tmp) || transform3(tmp));
}
bool transform6(const Matrix& in) {
for (int i = 1; i <= in.n; i++) {
for (int j = 1; j < in.n; j++) {
if (in.map[i][j] != to.map[i][j])
return 0;
}
}
return 1;
}
int main() {
scanf("%d", &from.n);
to.n = from.n;
string tmp;
getline(cin, tmp);
for (int i = 1; i <= from.n; i++) {
getline(cin, tmp);
for (int j = 0; j < from.n; j++)
from.map[i][j + 1] = tmp[j];
}
for (int i = 1; i <= to.n; i++) {
getline(cin, tmp);
for (int j = 0; j < to.n; j++)
to.map[i][j + 1] = tmp[j];
}
if (transform1(from) == 1) {
printf("1");
exit(0);
}
if (transform2(from) == 1) {
printf("2");
exit(0);
}
if (transform3(from) == 1) {
printf("3");
exit(0);
}
if (transform4(from) == 1) {
printf("4");
exit(0);
}
if (transform5(from) == 1) {
printf("5");
exit(0);
}
if (transform6(from) == 1) {
printf("6");
exit(0);
}
printf("7");
return 0;
}