USACO transformations 方块转换

题目描述

一块N x N(1<=N<=10)正方形的黑白瓦片的图案要被转换成新的正方形图案。写一个程序来找出将原始图案按照以下列转换方法转换成新图案的最小方式:

1:转90度:图案按顺时针转90度。

2:转180度:图案按顺时针转180度。

3:转270度:图案按顺时针转270度。

4:反射:图案在水平方向翻转(以中央铅垂线为中心形成原图案的镜像)。

5:组合:图案在水平方向翻转,然后再按照1到3之间的一种再次转换。

6:不改变:原图案不改变。

7:无效转换:无法用以上方法得到新图案。

如果有多种可用的转换方法,请选择序号最小的那个。

只使用1–7中的一个步骤来完成这次转换。

输入格式:

第一行: 单独的一个整数N。

第二行到第N+1行: N行每行N个字符(不是“@”就是“-”);这是转换前的正方形。

第N+2行到第2*N+1行: N行每行N个字符(不是“@”就是“-”);这是转换后的正方形。

输出格式:

单独的一行包括1到7之间的一个数字(在上文已描述)表明需要将转换前的正方形变为转换后的正方形的转换方法。

输入样例1:

输入样例1

输出样例1:

1


解题思路

1-4每一个都是纯模拟,如果知道规律,就可以很轻松的做出来。
第五个就是先做第四项,然后用一个数组保存,然后再旋转

代码

#include<iostream>
#include <cstdio>
using namespace std;
char m[110][110];
char tmp[110][110];
char ans[110][110];
int main(){
//	freopen("transform.in","r",stdin);
//	freopen("transform.out","w",stdout);
	int n;
	cin>>n;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			cin>>m[i][j];
		}
	}
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			cin>>ans[i][j];
		}
	}
	
	
	
	
	
	
	
	
	
	
	bool yn=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			tmp[j][n-1-i]=m[i][j];
		}
	}
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			if(tmp[i][j]!=ans[i][j]){
				yn=true;
			}
		}
	}
	if(yn==false){
		cout<<1<<endl;
		return 0;
	}
	//OK
	
	
	
	yn=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			tmp[n-1-i][n-1-j]=m[i][j];
		}
	}
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			if(tmp[i][j]!=ans[i][j]){
				yn=true;
			}
		}
	}
	if(yn==false){
		cout<<2<<endl;
		return 0;
	}
	
	
	
	
	
	
	
	
	
	
	
	yn=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			tmp[n-1-j][i]=m[i][j];
		}
	}
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			if(tmp[i][j]!=ans[i][j]){
				yn=true;
			}
		}
	}
	if(yn==false){
		cout<<3<<endl;
		return 0;
	}
	
	
	
	
	
		yn=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			tmp[i][n-1-j]=m[i][j];
		}
	}
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			if(tmp[i][j]!=ans[i][j]){
				yn=true;
			}
		}
	}
	if(yn==false){
		cout<<4<<endl;
		return 0;
	}
	
	
	
	
	char tmp2[110][110];
	
		yn=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			tmp2[n-1-j][i]=tmp[i][j];
		}
	}
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
//			cout<<tmp2[i][j];
			if(tmp2[i][j]!=ans[i][j]){
				yn=true;
			}
		}
//		cout<<endl;
	}
	if(yn==false){
		cout<<5<<endl;
		return 0;
	}
	
	
	
	
	
	
	
	
	
	
	
	
	
	
			yn=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			tmp2[j][n-1-i]=tmp[i][j];
		}
	}
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
//			cout<<tmp2[i][j];
			if(tmp2[i][j]!=ans[i][j]){
				yn=true;
			}
		}
//		cout<<endl;
	}
	if(yn==false){
		cout<<5<<endl;
		return 0;
	}
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
			yn=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			tmp2[n-1-i][n-1-j]=tmp[i][j];
		}
	}
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
//			cout<<tmp2[i][j];
			if(tmp2[i][j]!=ans[i][j]){
				yn=true;
			}
		}
//		cout<<endl;
	}
	if(yn==false){
		cout<<5<<endl;
		return 0;
	}
	
	
	
	
	
	
	yn=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			if(m[i][j]!=ans[i][j]){
				yn=true;
			}
		}
	}
	if(yn==false){
		cout<<6<<endl;
		return 0;
	}
	
	cout<<7<<endl;
	return 0;
} 

猜你喜欢

转载自blog.csdn.net/johnwayne0317/article/details/84758433