一块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. out与ref修饰符

    out修饰符 定义 作用 使用注意 总结 定义 out意为output,所以被out修饰的参数叫做输出参数. 通过使用out修饰的参数,方法可以返回对应参数的值   作用 先看一个例子 定义变量:   ...

  2. Adsafe 导致win10 中窗口错位

    域账号使用,出现上述情况,干掉后一切恢复正常... 还好家里的本地管理员账号使用一切正常,不然又被广告占领了

  3. LoadRunner:VuGen开发脚本步骤(二)

    一.介绍 Loadrunner的场景能够描述在测试活动中发生的各种事件.一个场景包括一个运行虚拟用 户活动的Load Generator 机器列表,一个测试脚本的列表以及大量的虚拟用户和虚拟用户组 二 ...

  4. 获取 web 项目的绝对路径

    获取 web 项目的绝对路径 <% String path = request.getContextPath(); String basePath = request.getScheme()+& ...

  5. SASS详解之混合(mixins)

    SASS详解之混合(mixins)可以出现在SASS的任何地方.有很多类名具有相同或者相似的样式,就可以用SASS中的混合(mixins)来进行编写,然后针对不同类名的不同样式逐一编写. 定义一个混合 ...

  6. 如果修改GeneXus Android的一些源码文件(FlexibleClient)

    在使用GeneXus开发Android应用的过程中遇到了一个问题,使用tabs控件时发现默认高度过高,和UI设计要求的高度不一致,找了很久发现没有地方设置.后来联系了GeneXus中国厂商,得到了答复 ...

  7. zookeeper分布式算法和部署

    算法摘要 安装 配置 监控 创建节点 二阶段提交(Two-Phase Commit) 投票和执行 协调者向参与者发送事务内容,询问是否可以提交,各参与者节点执行事务并向协调者反馈 如果所有参与者反馈y ...

  8. Python Socket多线程并发

    1.SocketServer模块编写的TCP服务器端代码 Socketserver原理图 服务端: import SocketServer #导入SocketServer,多线程并发由此类实现 cla ...

  9. JavaScript初步

    隐式转换 其他类型转换成布尔类型: undefined --> false null --> false 0或者0.0或者NaN --> false 字符串长度为0 --> f ...

  10. 【坐标变换】【二维偏序】【线段树】Gym - 100820G - Racing Gems

    题意:第一象限有n个点,你从x正半轴任选一个位置出发,vy恒定,vx可以任意变化,不过只能在-vy/r到vy/r之间变化,问你最多能经过多少个点. 暴力dp是n^2,不可取. 注意到,一个点,所能到达 ...