227 - Puzzle (UVA)

题目链接如下:

Online Judge

这道题其实没有很难,但有一个巨坑的点,就是我估计,原题的格式是符合题意的,就算一行中第五个字符是' ',照样是给出来的;但洛谷给出的样例,最后一个字符是' ',直接是跳过的。所以,能被uva AC的代码,跑洛谷的样例是错误的......就因为这,我在这道题上耗费了好几个钟头......

我的AC代码如下:

cpp 复制代码
#include <cstdio>

int u, v, kase;
char ch;
char a[5][5];
bool flag = true;

int main(){
    kase = 0;
    while(scanf("%c", &ch) == 1 && ch != 'Z'){
        a[0][0] = ch;
        if(a[0][0] == ' '){
            u = v = 0;
        }
        for(int i = 0; i < 5; ++i){
            for(int j = (i == 0 ? 1 : 0); j < 5; ++j){
                scanf("%c", &a[i][j]);
                if(a[i][j] == ' '){
                    u = i;
                    v = j;
                }
            }
            getchar();
        }
        flag = true;
        while(scanf("%c", &ch) == 1 && ch != '0'){
            if(!flag){
                continue;
            }
            if(ch == 'A'){
                if(u == 0){
                    flag = false;
                } else{
                    a[u][v] = a[u - 1][v];
                    u--;
                }
            } else if(ch == 'B'){
                if(u == 4){
                    flag = false;
                } else{
                    a[u][v] = a[u + 1][v];
                    u++;
                }
            } else if(ch == 'L'){
                if(v == 0){
                    flag = false;
                } else{
                    a[u][v] = a[u][v - 1];
                    v--;
                }
            } else if(ch == 'R'){
                if(v == 4){
                    flag = false;
                } else{
                    a[u][v] = a[u][v + 1];
                    v++;
                }
            }
        }
        getchar();
        printf("%s", kase == 0 ? "" : "\n");
        printf("Puzzle #%d:\n", ++kase);
        if(!flag){
            printf("This puzzle has no final configuration.\n");
            continue;
        }
        a[u][v] = ' ';
        for(int i = 0; i < 5; ++i){
            for(int j = 0; j < 5; ++j){
                printf("%c%s", a[i][j], j == 4 ? "\n" : " ");
            }
        }
    }
    return 0;
}
相关推荐
黑牛先生1 小时前
【GDB】调试Jsoncpp源码
开发语言·c++·算法
大大大大物~2 小时前
JVM 之 垃圾回收算法及其内部实现原理【垃圾回收的核心问题有哪些?分别怎么解决的?可达性分析解决了什么问题?回收算法有哪些?内部怎么实现的?】
jvm·算法
不夜牛仔2 小时前
算法笔记19 - 图和通用结构 | 图的两种遍历 | 三种拓扑排序 | 两种最小生成树算法Kruskal, Prim | 最短路径算法Dijkstra
笔记·算法
小龙报2 小时前
【算法通关指南:基础算法篇】高精度专题:一篇破除超数运算问题
c语言·数据结构·c++·算法·链表·贪心算法·visual studio
ULTRA??2 小时前
Informed RRT*算法,并包含圆形障碍物环境
人工智能·python·算法
Yupureki2 小时前
《算法竞赛从入门到国奖》算法基础:入门篇-双指针
c语言·开发语言·数据结构·c++·算法·visual studio
AshinGau2 小时前
权重衰减(Weight Decay)
神经网络·算法
Liangwei Lin2 小时前
洛谷 P3367 【模板】并查集
算法
dyxal2 小时前
动态规划:给“最优解”一张记住过去的备忘录
算法·动态规划·代理模式
炽烈小老头2 小时前
【每天学习一点算法2025/12/16】二叉树的最大深度
学习·算法