题目

aslky 有一个 n×n 的矩形,每个位置上都有一个数,有 q 次操作,每次他会让你上下翻转 (UD),左右反转 (LR),顺时针旋转 90∘(SZ),逆时针旋转 90∘(NZ),请你输出最后的矩形。

输入格式

第一行,两个数 n,q。

接下来 n 行,每行 n个数,代表矩形。

接下来 q 行,每行一个字符串,代表操作。

输出格式

n 行,每行 n 个数代表矩形。

数据规模与约定

对于 10% 的数据,1≤n≤10;

对于 100% 的数据,1≤n≤1000,1≤q≤1e6

Sample Input

3 3
1 2 3
1 2 3
1 2 3
NZ
SZ
SZ

Sample Output

1 1 1
2 2 2
3 3 3

题解

一次操作的复杂度为O(N^2),直接模拟复杂度为O(q*N^2),n<=1000,q<=1e6,计算次数为1e12,直接模拟必定超时,需要优化。如果该题无翻转变换只有旋转变化就简单了,SZ和NZ可以相互抵消,最后再对结果模4,就能大程度的优化操作次数。但加上翻转变化,那就要考虑两种翻转变化的优化,以及翻转变化和旋转变化的相互影响,还有图像在这几种变化中拥有多少种状态。

通过画图模拟,我们可以得出,图像在这2种变化中共有8种状态,首先是,原图像只通过旋转可以有4种状态,加上翻转变化后,我们发现无论是上下翻转还是左右翻转,其实都是把图像变成镜像面,图像在这种镜像面同样有4种形态,合起来共8种。

对翻转变化的优化,我们容易发现,同时经过两次上下翻转或者左右翻转后图像复原,所以,单向翻转变化可以模2.再对翻转变化进行研究,发现图像经过一次上下翻转一次左右翻转,会脱离镜像图变为原图。归纳:一个图像经过一次翻转变化后变为镜像图,这个镜像图再经过一次翻转变换后复原为原图。

接下来是研究两种变化之间的关系。容易发现上下翻转的图像通过旋转可变为左右翻转的图像,通过这个性质我们可以得出一个等式:LR=UD+2*SZ.  通过这个等式我们可以把所有的左右翻转变化变为上下翻转变化加上旋转变化。

剩下的就是考虑在翻转变化后旋转变化有何影响,容易知道,在镜像图状态时,对图像的顺时针旋转将相当于原图像的逆时针旋转,逆时针亦然。

暴力模板

#include<iostream>
#include<algorithm>
using namespace std; int s[][];
int f[][];
int n;
void UD() {
for (int i = ; i < n / ; i++) {
for (int j = ; j < n; j++) {
swap(s[i][j], s[n - i - ][j]);
}
}
}
void LR() {
for (int i = ; i < n / ; i++) {
for (int j = ; j < n; j++) {
swap(s[j][i], s[j][n - i - ]);
}
} }
void SZ() { for (int i = ; i < n; i++) {
for (int j = ; j < n; j++) {
f[j][n - i - ] = s[i][j];
}
}
for (int i = ; i < n; i++) {
for (int j = ; j < n; j++) {
s[i][j] = f[i][j];
}
}
} void NZ() {
for (int i = ; i < n; i++) {
for (int j = ; j < n; j++) {
f[n - - j][i] = s[i][j];
}
}
for (int i = ; i < n; i++) {
for (int j = ; j < n; j++) {
s[i][j] = f[i][j];
}
} } void pr() {
for (int i = ; i < n; i++) {
for (int j = ; j < n; j++)
cout << s[i][j] << ' ';
cout << '\n';
}
} int main() {
ios::sync_with_stdio();
int q;
char com[];
cin >> n >> q;
for (int i = ; i < n; i++)
for (int j = ; j < n; j++)
cin >> s[i][j]; while (q--) {
cin >> com;
switch (com[]) {
case 'U':
UD();
break;
case 'L':
LR();
break;
case 'S':
SZ();
break;
case 'N':
NZ();
break;
}
/*pr();
cout << '\n';*/
} pr();
}

数据生成

#include<iostream>
#include<time.h>
#include<algorithm>
#include<map>
using namespace std;
int r(int l, int r) {
return rand() % (r+ - l) + l;
}
char s[][] = { "UD","LR","SZ","NZ" }; int main() {
ios::sync_with_stdio(); srand(time());
int n=, q=r(,);
int k = ;
cout << n << ' ' << q << '\n';
cout << "1 2\n";
cout << "4 3\n";
while (q--) {
cout << s[r(, )] << '\n';
}
return ;
}

AC代码

#include<iostream>
#include<algorithm>
using namespace std; int s[][];
int f[][];
int n;
void UD() {
for (int i = ; i < n/; i++) {
for (int j = ; j < n; j++) {
swap(s[i][j], s[n - i-][j]);
}
}
} void SZ() { for (int i = ; i < n; i++) {
for (int j = ; j < n; j++) {
f[j][n - i-] = s[i][j];
}
}
for (int i = ; i < n; i++) {
for (int j = ; j < n; j++) {
s[i][j] = f[i][j];
}
}
} void pr() {
for (int i = ; i < n; i++) {
for (int j = ; j < n; j++)
cout << s[i][j] << ' ';
cout << '\n';
}
} int main() {
ios::sync_with_stdio();
int q;
char com[];
cin >> n >> q;
for (int i = ; i < n; i++)
for (int j = ; j < n; j++)
cin >> s[i][j]; int flag = ;
int sz = ;
while (q--) {
cin >> com;
switch (com[]){
case 'U':
if (flag == ) {
sz++;
flag *= -;
}
else {
sz--;
flag *= -;
}
break;
case 'L':
if (flag == ) {
sz--;
flag *= -;
}
else {
sz++;
flag *= -;
}
break; case 'S':
if (flag == ) {
sz++;
}
else {
sz--;
}
break;
case 'N':
if (flag == ) {
sz--;
}
else {
sz++;
}
break;
}
if(sz>=)
sz %= ;
else {
sz %= ;
sz += ;
}
}
if (flag==) {
while (sz--)SZ();
}
else {
sz--;
sz += ;
sz %= ;
while (sz--)SZ();
UD(); } pr(); }

【几何+模拟】二次元变换 计蒜客 - T3213的更多相关文章

  1. 计蒜客 NOIP 提高组模拟竞赛第一试 补记

    计蒜客 NOIP 提高组模拟竞赛第一试 补记 A. 广场车神 题目大意: 一个\(n\times m(n,m\le2000)\)的网格,初始时位于左下角的\((1,1)\)处,终点在右上角的\((n, ...

  2. 计蒜客T2202 数三角形(提高组2017模拟赛(三)day2T3) LZOJ3878攻略

    今天模拟赛考了一道计蒜客NOIP2017模拟赛(三)day2T3的数三角形,原题链接 https://nanti.jisuanke.com/t/T2202 ,LZOJ3878攻略.场上想了很久都没转化 ...

  3. 计蒜客模拟赛5 D2T1 成绩统计

    又到了一年一度的新生入学季了,清华和北大的计算机系同学都参加了同一场开学考试(因为两校兄弟情谊深厚嘛,来一场联考还是很正常的). 不幸的是,正当老师要统计大家的成绩时,世界上的所有计算机全部瘫痪了. ...

  4. 计蒜客 31436 - 提高水平 - [状压DP]

    题目链接:https://nanti.jisuanke.com/t/31436 作为一名车手,为了提高自身的姿势水平,平时的练习是必不可少的.小 J 每天的训练包含 $N$ 个训练项目,他会按照某个顺 ...

  5. 计蒜客 31434 - 广场车神 - [DP+前缀和]

    题目链接:https://nanti.jisuanke.com/t/31434 小 D 是一位著名的车手,他热衷于在广场上飙车.每年儿童节过后,小 D 都会在广场上举行一场别样的车技大赛. 小 D 所 ...

  6. [计蒜客] 矿石采集【记搜、Tarjan缩点+期望Dp】

    Online Judge:计蒜客信息学3月提高组模拟赛 Label:记搜,TarJan缩点,树状数组,期望Dp 题解 整个题目由毫无关联的两个问题组合成: part1 问题:对于每个询问的起点终点,求 ...

  7. 计蒜客 作弊揭发者(string的应用)

    鉴于我市拥堵的交通状况,市政交管部门经过听证决定在道路两侧安置自动停车收费系统.当车辆驶入车位,系统会通过配有的摄像头拍摄车辆画面,通过识别车牌上的数字.字母序列识别车牌,通过连接车管所车辆信息数据库 ...

  8. 计蒜客的一道题dfs

    这是我无聊时在计蒜客发现的一道题. 题意: 蒜头君有一天闲来无事和小萌一起玩游戏,游戏的内容是这样的:他们不知道从哪里找到了N根不同长度的木棍, 看谁能猜出这些木棍一共能拼出多少个不同的不等边三角形. ...

  9. 计蒜客 等边三角形 dfs

    题目: https://www.jisuanke.com/course/2291/182238 思路: 1.dfs(int a,int b,int c,int index)//a,b,c三条边的边长, ...

随机推荐

  1. Window下将nginx配置为开机自动启动

    前两天看到公司window服务器上面有个nginx在跑,重启服务器后没有自动启动,需要手动运行nginx,甚是麻烦呀 上网找了一下关于将nginx配置为系统服务并且开机自动启动的解决方案,这里mark ...

  2. 专家解读:利用Angular项目与数据库融合实例

    摘要:面对如何在现有的低版本的框架服务上,运行新版本的前端服务问题,华为云前端推出了一种融合方案,该方案能让独立的Angular项目整体运行在低版本的框架服务上,通过各种适配手段,让Angular项目 ...

  3. JavaWeb网上图书商城完整项目--day02-25.查询所有分类功能之流程分析

    分类模块的业务流程入下面所示:

  4. linux下的c语言编程学习笔记

    视频参看csdn学院王阳和下面的linux环境下c语言编程基础相当的经典,其中王阳的视频讲的很好,相当的经典 编译hellogcc.c需要依赖/home目录下的头文件 为了避免同一个文件被includ ...

  5. ECSHOP 2.5.1 二次开发文档【文件结构说明和数据库表分析】

    ecshop文件架构说明 /* ECShop 2.5.1 的结构图及各文件相应功能介绍 ECShop2.5.1_Beta upload 的目录 ┣ activity.php 活动列表 ┣ affich ...

  6. Java 添加、提取PDF中的图片

    Spire.Cloud.SDK for Java提供了PdfImagesApi接口可用于添加图片到PDF文档addImage().提取PDF中的图片extractImages(),具体操作步骤和Jav ...

  7. Netty 源码解析(六): Channel 的 register 操作

    原创申明:本文由公众号[猿灯塔]原创,转载请说明出处标注 今天是猿灯塔“365篇原创计划”第六篇. 接下来的时间灯塔君持续更新Netty系列一共九篇   Netty 源码解析(一 ):开始 Netty ...

  8. 自适应高度输入框(contenteditable/textarea)

      一.用div模拟textarea div模拟输入域可以根据输入内容自动伸缩,而input和textarea输入内容较多时,高度固定,内容会显示不全. 1.坑1(IOS端无法输入) 在取消全局默认样 ...

  9. JAVA基础笔记10-11-12-13-14

    十.今日内容介绍 1.继承 2.抽象类 3.综合案例---员工类系列定义 01继承的概述 *A:继承的概念 *a:继承描述的是事物之间的所属关系,通过继承可以使多种事物之间形成一种关系体系 *b:在J ...

  10. day49 数据库终章

    目录 一.pymysql补充 二.数据库补充 1 视图(了解) 2 触发器(了解) 3 事务 4 存储过程(了解) 5 函数 6 流程控制 7 索引 8 b+树 9 聚集索引(primary key) ...