[刷题]算法竞赛入门经典(第2版) 4-4/UVa253 - Cube painting

本文介绍了一种使用C++解决立方体旋转匹配问题的方法,通过旋转操作来判断六个面是否能够组成一个完整的立方体。文章详细展示了如何通过旋转算法进行匹配,并提供了代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

书上具体所有题目:http://pan.baidu.com/s/1hssH0KO
代码:(Accepted,0 ms)

#include<iostream>
char str[15];

void change(int b) {//更换顶上的面
    char t;
    if(b) t = str[0], str[0] = str[1], str[1] = str[5], str[5] = str[3], str[3] = t;
    else t = str[0], str[0] = str[4], str[4] = str[5], str[5] = str[2], str[2] = t;
}

bool compare() {
    if (str[0] != str[6] || str[5] != str[11]) return 0;
    int i,j;
    for (i = 0;i < 4;++i) {
        for (j = 0;j < 4;++j)
            if (str[(j + i) % 4 + 1] != str[j + 7]) break;
        if (j == 4) return 1;
    }
    return 0;
}

int main()
{
    //freopen("in.txt", "r", stdin);
    while (scanf("%s", str) != -1) {
        int i;
        i = str[3], str[3] = str[4], str[4] = i;
        i = str[9], str[9] = str[10], str[10] = i;
        for (i = 0;i < 6;++i) {
            //printf("----------------%c%c%c%c%c%c\n", str[0], str[1], str[2], str[3], str[4], str[5]);
            if (compare()) break;
            if(i!=5) change(i%2);
        }
        printf((i < 6 ? "TRUE\n" : "FALSE\n"));
    }
    return 0;
}

分析:这题告诉我认真审题的重要性。。。题目给的各个面的输入顺序是123546,即各个对面为1-6,2-5,3-4,而我当作了123456。。。于是面与面的对应关系错了。。我说怎么老是WA。
很奇怪题目为什么要这么给各个面的顺序,按他这样做起来比较烦(至少我没发现他故意这样排能有什么快速的途径)于是我把地4和第5个数据换了个位:

i = str[3], str[3] = str[4], str[4] = i;
i = str[9], str[9] = str[10], str[10] = i;

这样绕着上下两个面的中点所形成的直线旋转比较方便(也算是历史遗留问题。。。如果一开始就没看错题目的话,应该会想别的方法,现在WA的怕了,就直接转化一下数据了事)。
题目一共有6*4=24种情况,即6个面分别朝向上方时周围4各面旋转4次,所以甚至直接枚举也是极好的。VJ看到直接列6个数组,代表各个面朝上时其他面所在的情况,代码极其简洁:
http://acm.hust.edu.cn/vjudge/problem/source/6310914。这里因为量不大,用枚举很不错啊。而我的还要做5次旋转,旋转需要要不停地赋值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值