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

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

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

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

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

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

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

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

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

仅仅使用1--7中的一个步骤来完毕这次转换。

[编辑]格式

PROGRAM NAME: transform

INPUT FORMAT:

(file transform.in)

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

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

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

OUTPUT FORMAT:

(file transform.out)

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

[编辑]SAMPLE INPUT

3
@-@
---
@@-
@-@
@--
--@

[编辑]SAMPLE OUTPUT

1
/*
ID: zwcwu52
PROG: transform
LANG: C++
*/ #include <iostream>
#include <fstream>
#include <string> using namespace std; char blkSrc[10][10], blkDst[10][10]; //源方阵、目标方阵 int main()
{
ofstream fout ("transform.out");
ifstream fin ("transform.in"); unsigned N; //阶数
unsigned num = 7; //方案数字 fin >> N; //读取源方阵
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{fin >> blkSrc[i][j];}
} //读取目标方阵
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{fin >> blkDst[i][j];}
} do
{
bool b = true; //b 标识是否全然符合 //按方案1检測
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{
if(blkSrc[i][j] != blkDst[j][N - i - 1])
{
b = false;
break;
}
}
}
if(true == b)
{
num = 1;
break;
} //按方案2检測
b = true;
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{
if(blkSrc[i][j] != blkDst[N- i - 1][N - j - 1])
{
b = false;
break;
}
}
}
if(true == b)
{
num = 2;
break;
} //按方案3检測
b = true;
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{
if(blkSrc[i][j] != blkDst[N- j - 1][i])
{
b = false;
break;
}
}
}
if(true == b)
{
num = 3;
break;
} //按方案4检測
b = true;
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{
if(blkSrc[i][j] != blkDst[i][N - j - 1])
{
b = false;
break;
}
}
}
if(true == b)
{
num = 4;
break;
} //按方案5检測
b = true;
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{
if(blkSrc[i][j] != blkDst[N - j - 1][N - i - 1])
{
b = false;
break;
}
}
}
if(true == b)
{
num = 5;
break;
} //按方案5检測
b = true;
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{
if(blkSrc[i][j] != blkDst[N - i - 1][j])
{
b = false;
break;
}
}
}
if(true == b)
{
num = 5;
break;
} //按方案5检測
b = true;
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{
if(blkSrc[i][j] != blkDst[j][i])
{
b = false;
break;
}
}
}
if(true == b)
{
num = 5;
break;
} //按方案6检測
b = true;
for(unsigned i = 0; i < N; i++)
{ for(unsigned j = 0; j < N; j++)
{
if(blkSrc[i][j] != blkDst[i][j])
{
b = false;
break;
}
}
}
if(true == b)
{
num = 6;
break;
} }while(0); fout << num << endl; return 0;
}

【USACO1.2_2】★Transformations 方块转换的更多相关文章

  1. Transformations 方块转换 USACO 模拟 数组 数学 耐心

    1006: 1.2.2 Transformations 方块转换 时间限制: 1 Sec  内存限制: 128 MB提交: 10  解决: 7[提交] [状态] [讨论版] [命题人:外部导入] 题目 ...

  2. [USACO1.2.2]方块转换 Transformations

    P1205 [USACO1.2]方块转换 Transformations 标签 搜索/枚举 USACO 题目描述 一块N x N(1<=N<=10)正方形的黑白瓦片的图案要被转换成新的正方 ...

  3. Transformations 方块转换

    题目是中文题,就不做什么解释了,纯模拟题,主要要搞清楚这几种装换方式下标的变化: 第一种:顺时针旋转90度: c[j][n-i+1]=a[i][j]; 第二种:旋转180度: c[n-i+1][n-j ...

  4. USACO 1.2.2 Transformations 方块转换

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

  5. 洛谷 Transformations 方块转换

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

  6. 洛谷 P1205 [USACO1.2]方块转换 Transformations

    P1205 [USACO1.2]方块转换 Transformations 题目描述 一块N x N(1<=N<=10)正方形的黑白瓦片的图案要被转换成新的正方形图案.写一个程序来找出将原始 ...

  7. Spark Streaming之六:Transformations 普通的转换操作

    与RDD类似,DStream也提供了自己的一系列操作方法,这些操作可以分成四类: Transformations 普通的转换操作 Window Operations 窗口转换操作 Join Opera ...

  8. USACO Training Section 1.2 [USACO1.2]方块转换 Transformations

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

  9. 【USACO 1.2.2】方块转换

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

随机推荐

  1. python存取数据进阶技巧-pickle,array模块

    我们在存/取数据时,没有必要存成文本形式,多试试二进制形式,文本只是骗骗眼睛的,要更快和更高效 1.数组形式 如果我们需要一个之包含数字的列表,那就试试array.array,注意,不是numpy模块 ...

  2. [实战]MVC5+EF6+MySql企业网盘实战(15)——逻辑重构2

    写在前面 上篇文章修改文件上传的逻辑,这篇修改下文件下载的逻辑. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网盘实战(1) [实 ...

  3. Jquery 实现轮播图

    jq 轮播图 function banner_show(){ var left_btn = $("#banner_tag_left"); //获取左侧单击按钮 var right_ ...

  4. linux网络管理----网络基础

    1.1 ISO/OSI 七层模型 笔记: 打入ipconfig: mac地址:Media Access Control 也是物理地址,这是由网卡决定的.负责的是内网,也就是局域网通信. IPv4地址: ...

  5. java浅拷贝和深拷贝(基础也是很重要的)

    对象的copy你兴许只是懵懂,或者是并没在意,来了解下吧. 对于的github基础代码https://github.com/chywx/JavaSE 最近学习c++,跟java很是相像,在慕课网学习c ...

  6. SpringBoot学习(六)

    1.pom 文件 <?xml version="1.0" encoding="utf-8"?> <dependencies> <d ...

  7. python 写一个贪吃蛇游戏

    #!usr/bin/python #-*- coding:utf-8 -*- import random import curses s = curses.initscr() curses.curs_ ...

  8. HDU5904 LCIS 水题

    http://acm.hdu.edu.cn/showproblem.php?pid=5904:// 说是LCIS其实和LCIS没有一点儿关系的水题. 代码 #include<cstdio> ...

  9. Mac 配置几个环境变量

    终端    open -t ~/.bash_profile  打开.bash_profile export PATH=${PATH}:/Users/maxinliang/Android/sdk/pla ...

  10. SpringBoot 搭建简单聊天室

    SpringBoot 搭建简单聊天室(queue 点对点) 1.引用 SpringBoot 搭建 WebSocket 链接 https://www.cnblogs.com/yi1036943655/p ...