洛谷 P2630 图像变换
题目描述
给定3行3列的图像各像素点灰度值,给定最终图像,求最短、字典序最小的操作序列。
其中,可能的操作及对应字符有如下四种:
A:顺时针旋转90度;
B:逆时针旋转90度;
C:左右翻转;
D:上下翻转。
输入输出格式
输入格式:
一个矩阵,表示初始的图像。
一个矩阵,表示最终的图像。
输出格式:
最短、字典序最小的操作序列,保证长度不超过100000000,不保证有解(若长度不超过
100000000无解则输出“Poland cannot into space!!!”)。
输入输出样例
3 4 5
6 7 8
1 2 3
1 2 3
6 7 8
3 4 5
D
思路:最多顺时针转2次,逆时针转一次。上下反转一次,左右翻转一次。
然后就很好处理了,判断所有的情况的组合就好了。
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int map[][],tmp[][];
int judge(){
for(int i=;i<=;i++)
for(int j=;j<=;j++)
if(map[i][j]!=tmp[i][j]) return false;
return true;
}
void zhuan(){
int bns[][]={};
bns[][]=tmp[][];bns[][]=tmp[][];bns[][]=tmp[][];
bns[][]=tmp[][];bns[][]=tmp[][];bns[][]=tmp[][];
bns[][]=tmp[][];bns[][]=tmp[][];bns[][]=tmp[][];
for(int i=;i<=;i++)
for(int j=;j<=;j++) tmp[i][j]=bns[i][j];
}
void swap1(){ for(int i=;i<=;i++) swap(tmp[i][],tmp[i][]); }
void swap2(){ for(int j=;j<=;j++) swap(tmp[][j],tmp[][j]); }
int main(){
for(int i=;i<=;i++)
for(int j=;j<=;j++) scanf("%d",&map[i][j]);
for(int i=;i<=;i++)
for(int j=;j<=;j++) scanf("%d",&tmp[i][j]);
zhuan(); if(judge()){ cout<<"A";return ; }
zhuan(); if(judge()){ cout<<"AA";return ; }
zhuan(); if(judge()){ cout<<"B";return ; } zhuan();
swap1(); if(judge()){ cout<<"C";return ; }
zhuan(); if(judge()){ cout<<"AC";return ; }
zhuan(); if(judge()){ cout<<"D";return ; }
zhuan(); if(judge()){ cout<<"AC";return ; } zhuan();
swap2(); if(judge()){ cout<<"D";return ; }
zhuan(); if(judge()){ cout<<"AD";return ; }
zhuan(); if(judge()){ cout<<"AB";return ; }
zhuan(); if(judge()){ cout<<"BD";return ; } zhuan();
swap1();swap2(); if(judge()){ cout<<"CD";return ; }
zhuan(); if(judge()){ cout<<"ACD";return ; }
zhuan(); if(judge()){ cout<<"AACD";return ;}
zhuan(); if(judge()){ cout<<"BCD";return ; }
cout<<"Poland cannot into space!!!";
}
洛谷 P2630 图像变换的更多相关文章
- 洛谷P2630 题解
我先讲一下我的思路 将A,B,C,D四种操作用函数储存起来: 枚举所有可能出现的情况:A,B,C,D,AA,AB,AC,AD,BB,BC,BD,CC,CD,DD,ABC,ABD,ACD,BCD,ABC ...
- 洛谷1640 bzoj1854游戏 匈牙利就是又短又快
bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
- 洛谷P1108 低价购买[DP | LIS方案数]
题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...
- 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP
题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...
- 洛谷P1710 地铁涨价
P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交 讨论 题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...
- 洛谷P1371 NOI元丹
P1371 NOI元丹 71通过 394提交 题目提供者洛谷OnlineJudge 标签云端评测 难度普及/提高- 提交 讨论 题解 最新讨论 我觉得不需要讨论O long long 不够 没有取 ...
- 洛谷P1538迎春舞会之数字舞蹈
题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...
- 洛谷八月月赛Round1凄惨记
个人背景: 上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了 也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学 ...
随机推荐
- cuda windows运行时间限制
GTX1080的卡,8G的显存,写cuda时申请了2G的显存就莫名其妙的抛异常,昨天找了一天也没找出bug,去stackoverflow上问了下才知道是windows的事,需要修改注册表.问题链接 - ...
- 找出 alter system kill session ‘sid,serial#’ kill 掉的数据库会话对应进程
当我们使用alter system kill session ‘sid,serial#’ 在数据库中kill掉某个会话的时候,如果你观察仔细会发现v$session.paddr发生了改变,从而是的不能 ...
- 关于RoI pooling 层
ROIs Pooling顾名思义,是pooling层的一种,而且是针对ROIs的pooling: 整个 ROI 的过程,就是将这些 proposal 抠出来的过程,得到大小统一的 feature ma ...
- 虚拟机创建后该如何获取IP地址并访问互联网实用教程
之前在做项目的时候主机IP地址.网关.DNS.子网掩码等都是公司或者对方直接给提供的,但是如果我们自己想搭建一台虚拟机或者一台集群的话,手头又没有IP地址,该肿么办呢? 白慌,这里介绍一个小技巧, ...
- Json相关内容
一. 导入包:net.sf.json.JSONObject 代码 import net.sf.json.JSON; import net.sf.json.JSONArray; import net.s ...
- poj1284 && caioj 1159 欧拉函数1:原根
这道题不知道这个定理很难做出来. 除非暴力找规律. 我原本找的时候出了问题 暴力找出的从13及以上的答案就有问题了 因为13的12次方会溢出 那么该怎么做? 快速幂派上用场. 把前几个素数的答案找出来 ...
- pandas学习笔记 - 常见的数据处理方式
1.缺失值处理 - 拉格朗日插值法 input_file数据文件内容(存在部分缺失值): from scipy.interpolate import lagrange import pandas as ...
- 面试题——ArrayList和LinkedList的区别
List概括 先回顾一下List在Collection的框架图: 从图中可以看出: List是一个接口,他继承Collection接口,代表有序的队列. AbstractList是一个抽象类, ,它继 ...
- 洛谷 P3146 [USACO16OPEN]248
P3146 [USACO16OPEN]248 题目描述 Bessie likes downloading games to play on her cell phone, even though sh ...
- [转载]深入JVM锁机制-synchronized
转自:http://blog.csdn.net/chen77716/article/details/6618779,并加上少量自己的理解 目前在Java中存在两种锁机制:synchronized和Lo ...