博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
253:Cube painting
阅读量:6334 次
发布时间:2019-06-22

本文共 1657 字,大约阅读时间需要 5 分钟。

开始的想法:骰子无论怎么转,每个数字和其对面的数字的对应关系永远不会改变,所以只需要比较两个骰子的三对数字是否相同即可,也的确AC了,但是后来想想不太对。

#include
#include
using namespace std;char s[12];int vis[3];int main(){ while(scanf("%s",s) != EOF){ int i,j; memset(vis,0,sizeof(vis)); for(i = 0;i < 3;i++){ for(j = 6;j < 9;j++){ if(!vis[j-6] && ((s[i] == s[j] && s[5-i] == s[11-j+6]) || (s[i] == s[11-j+6] && s[5-i] == s[j]))){ vis[j-6] = 1; break; } } if(j == 9){ printf("FALSE\n"); break; } } if(i == 3) printf("TRUE\n"); } return 0;}

比如上图这种情况,虽然三组数字都对应相同,但是两个骰子明显是不一样的,所以只考虑三组数字是无法保证正确的,题目的测试数据不行啊。。。

新的想法:对于第二个骰子,首先确定其与第一个骰子第一个面所对应的面,即确定旋转轴;然后尝试四种可能的旋转情况(逆时针顺序比较四个相邻字母),依次比较两个骰子与第一个面相邻的四个面的字母是否对应相等,如果全部对应那么两枚骰子就是相同的。代码如下:

#include
#include
using namespace std;int cons[6][4] = {
{5,4,2,3},{1,4,6,3},{1,2,6,5},{1,5,6,2},{1,3,6,4},{5,3,2,4}};char s[12];int main(){ while(scanf("%s",s) != EOF){ int i,j,k; for(i = 6;i < 12;i++){ if(s[i] == s[0] && s[6+11-i] == s[5]){ for(j = 0;j < 4;j++){ int t = i - 6,cnt = 0,tc = j; for(k = 0;k < 4;k++){ if(s[cons[0][k] - 1] == s[6 + cons[t][(tc++)%4] - 1]) cnt++; } if(cnt == 4) break; } if(j < 4) break; } } printf("%s\n",i < 12 ? "TRUE" : "FALSE"); } return 0;}

转载于:https://www.cnblogs.com/JingwangLi/p/10202752.html

你可能感兴趣的文章
并查集的应用之求解无向图中的连接分量个数
查看>>
7个神奇的jQuery 3D插件
查看>>
在线浏览PDF之PDF.JS (附demo)
查看>>
波形捕捉:(3)"捕捉设备"性能
查看>>
AliOS Things lorawanapp应用介绍
查看>>
美国人的网站推广方式千奇百怪
查看>>
java web学习-1
查看>>
用maven+springMVC创建一个项目
查看>>
linux设备驱动第四篇:以oops信息定位代码行为例谈驱动调试方法
查看>>
redis知识点整理
查看>>
Hello World
查看>>
Spring3全注解配置
查看>>
ThreadLocal真会内存泄露?
查看>>
IntelliJ IDEA
查看>>
低版本mybatis不能用PageHeper插件的时候用这个分页
查看>>
javaweb使用自定义id,快速编码与生成ID
查看>>
[leetcode] Add Two Numbers
查看>>
elasticsearch suggest 的几种使用-completion 的基本 使用
查看>>
04-【MongoDB入门教程】mongo命令行
查看>>
字符串与整数之间的转换
查看>>