方块转换 Transformations(洛谷)(浇浇我)

2023-12-25 13:20

本文主要是介绍方块转换 Transformations(洛谷)(浇浇我),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

一块 n × n n \times n n×n 正方形的黑白瓦片的图案要被转换成新的正方形图案。写一个程序来找出将原始图案按照以下列转换方法转换成新图案的最小方式:

  • 90 ° 90\degree 90°:图案按顺时针转 90 ° 90\degree 90°

  • 180 ° 180\degree 180°:图案按顺时针转 180 ° 180\degree 180°

  • 270 ° 270\degree 270°:图案按顺时针转 270 ° 270\degree 270°

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

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

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

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

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

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

输入格式

第一行一个正整数 n n n

然后 n n n 行,每行 n n n 个字符,全部为 @-,表示初始的正方形。

接下来 n n n 行,每行 n n n 个字符,全部为 @-,表示最终的正方形。

输出格式

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

样例 #1

样例输入 #1

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

样例输出 #1

1

提示

【数据范围】
对于 100 % 100\% 100% 的数据, 1 ≤ n ≤ 10 1\le n \le 10 1n10

题目翻译来自 NOCOW。

USACO Training Section 1.2

import numpy as np
def method1(data1):data1=np.array(data1)return np.rot90(data1,3)
def method2(data1):data1 = np.array(data1)return np.rot90(data1,2)
def method3(data1):data1 = np.array(data1)return np.rot90(data1,1)
def method4(data1):length=len(data1)key=int(length/2)for item in range(length):for jtem in range(key):flag=data1[item][jtem]data1[item][jtem]=data1[item][length-jtem-1]data1[item][length-jtem-1]=flagpasspassreturn data1
def method5(data1,data2):if (data2==method1(method4(data1))).all() or (data2==method2(method4(data1))).all() or (data2==method3(method4(data1))).all():return Truereturn False
def method6(data1,data2):if (data1==data2).all():return Truereturn False
if __name__ == "__main__":num = int(input())data1 = [[''] * num for _ in range(num)]data2 = [[''] * num for _ in range(num)]for item in range(num):stem = str(input())for jtem in range(num):data1[item][jtem] = stem[jtem]passfor item in range(num):stem = str(input())for jtem in range(num):data2[item][jtem] = stem[jtem]passdata2=np.array(data2)if (data2==method1(data1)).all():print(1)passelif (data2==method2(data1)).all():print(2)passelif (data2==method3(data1)).all():print(3)passelif (data2==method4(data1)).all():print(4)passelif method5(data1,data2):print(5)passelif method6(data1,data2):print(6)passelse:print(7)passpass

我实在调不出来了,最后一个样例过不了,那位佬救一下,我都输出了method5(data1,data2)了就是True,但是就是不进入那个if语句。输出了一下两个数组的值,用了一次子函数,第一个数组就直接变了,我只是返回函数值,不是直接对数组进行操作,为啥会变来变去。python好不方便,想起报了pytho组的竞赛就后悔。好不如c++。谁教一下我,是对全局变量和局部变量的了解有错误吗。。。。请添加图片描述
请添加图片描述
反正改了一下,这两个测试只能过一个,但是这两个测试的变化类型是一样的,真的抽象。

2的数据:

5
-@@@-
-@@--
-@---
-----
-----
-----
----@
---@@
--@@@
-----

输出5

7的数据:

4
@-@@
@@@@
@@@@
@@@@
@@@@
@@@@
@@@@
@-@@

输出5

这篇关于方块转换 Transformations(洛谷)(浇浇我)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/535664

相关文章

usaco 1.2 Transformations(模拟)

我的做法就是一个一个情况枚举出来 注意计算公式: ( 变换后的矩阵记为C) 顺时针旋转90°:C[i] [j]=A[n-j-1] [i] (旋转180°和270° 可以多转几个九十度来推) 对称:C[i] [n-j-1]=A[i] [j] 代码有点长 。。。 /*ID: who jayLANG: C++TASK: transform*/#include<

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };

C++实现俄罗斯方块(Windows控制台版)

C++实现俄罗斯方块(Windows控制台版) 在油管上看到一个使用C++控制台编写的俄罗斯方块小游戏,源代码200多行,B站上也有相关的讲解视频,非常不错,值得学习。 B站讲解视频地址为:【百万好评】国外技术大神C++游戏编程实战教程,油管580W收藏,新手10小时入门,并快速达到游戏开发能力(中英字幕) B站 CSDN博主千帐灯无此声还为此写了一篇博客:C++实现俄罗斯方块(源码+详解),讲

数据流与Bitmap之间相互转换

把获得的数据流转换成一副图片(Bitmap) 其原理就是把获得倒的数据流序列化到内存中,然后经过加工,在把数据从内存中反序列化出来就行了。 难点就是在如何实现加工。因为Bitmap有一个专有的格式,我们常称这个格式为数据头。加工的过程就是要把这个数据头与我们之前获得的数据流合并起来。(也就是要把这个头加入到我们之前获得的数据流的前面)      那么这个头是

高斯平面直角坐标讲解,以及地理坐标转换高斯平面直角坐标

高斯平面直角坐标系(Gauss-Krüger 坐标系)是基于 高斯-克吕格投影 的一种常见的平面坐标系统,主要用于地理信息系统 (GIS)、测绘和工程等领域。该坐标系将地球表面的经纬度(地理坐标)通过一种投影方式转换为平面直角坐标,以便在二维平面中进行距离、面积和角度的计算。 一 投影原理 高斯平面直角坐标系使用的是 高斯-克吕格投影(Gauss-Krüger Projection),这是 横

VC环境下整型转换为字符串型(2)

在串口下位机的发送中,可能会用到需要发送数字,显示为字符串型的 和上一篇文字《串口中字符串转换为整型》一正一反,知识点学习会了: #include<iostream.h> #include <stdio.h> #include <string.h>   void inttostr(int m,unsigned char * str) { int length=0;   int tmp,te

时间日期与时间戳转换(Linux C)

本文主要学习三个知识点,第一是UTC时间、GMT时间的概念;第二是在Unix环境下UTC时间与时间戳的转换;第三是在C语言中如何修改时区。 本文参考了《UNP》以及 http://blog.csdn.net/foxir/article/details/43916601 http://blog.csdn.net/ljafl9988/article/details/16847935 一、

高精度计算(代码加解析,洛谷p1601,p1303)除法待更新

目录 高精度加法 高精度减法 高精度乘法 高精度加法 我们知道在c++语言中任何数据类型都有一定的表示范围。当两个被加数很大时,正常加法不能得到精确解。在小学,我们做加法都采用竖式方法。那么我们也只需要按照加法进位的方式就能得到最终解。 8 5 6+ 2 5 5-------1 1 1 1 加法进位: c[i] = a[i] + b[i];if(c[i] >=

点云数据常见的坐标系有哪些,如何进行转换?

文章目录 一、点云坐标系分类1. 世界坐标系2. 相机坐标系3. 极坐标系4. 笛卡尔坐标系(直角坐标系):5. 传感器坐标系6. 地理坐标系 二、坐标系转换方法1. 地理坐标系与投影坐标系之间的转换2. 投影坐标系与局部坐标系之间的转换3. 局部坐标系与3D模型坐标系之间的转换4. 相机坐标系与其他坐标系之间的转换5. 传感器坐标系与其他坐标系之间的转换 三、坐标系转换工具 一