mirror of
https://git.sb/baoshuo/OI-codes.git
synced 2025-01-11 23:31:58 +00:00
P1205 [USACO1.2]方块转换 Transformations
R36572888
This commit is contained in:
parent
39f20723eb
commit
2d5a4841a8
116
problem/P1205/P1205.cpp
Normal file
116
problem/P1205/P1205.cpp
Normal 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;
|
||||
}
|
Loading…
Reference in New Issue
Block a user