uva227 - Puzzle

要注意的點:

(1)用c++的cin輸入流會遇到空格不能輸入的情況。(一些輸入的函數:http://www.cnblogs.com/flatfoosie/archive/2010/12/22/1914055.html)

(2)要儘量把數組的初始開到(1,1),防止越界的情況。


以下是代碼:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
void f(char a,int &xx,int &yy)
{
    if(a=='A') xx=-1,yy=0;
    else if(a=='B') xx=1,yy=0;
    else if(a=='R') xx=0,yy=1;
    else if(a=='L') xx=0,yy=-1;
}
int main()
{
    //freopen("in.txt","r",stdin);
    //freopen("out.txt","w",stdout);
    char a[10][10]={};
    int cnt=0;
    while(gets(a[1]+1)&&a[1][1]!='Z')
    {
        ++cnt;
        if(cnt>1) printf("\n");
        printf("Puzzle #%d:\n",cnt);
        for(int i=2;i<=5;i++)
            gets(a[i]+1);
        int x,y;
        for(int i=1;i<=5;i++)
            for(int j=1;j<=5;j++)
                if(a[i][j]==' ')
                    x=i,y=j;
        char b[100]={};
        cin.getline(b,100,'0');
        getchar();
        bool flag=1;
        for(int i=0;b[i]!='\0';i++)
        {
            if(b[i]=='\n') continue;
            int xx=0,yy=0;
            f(b[i],xx,yy);
            if(a[x+xx][y+yy]=='\0')
            {
                flag=0;
                printf("This puzzle has no final configuration.\n");
                break;
            }
            char t=a[x+xx][y+yy];
            a[x+xx][y+yy]=a[x][y];
            a[x][y]=t;
            x=x+xx,y=y+yy;
        }
        if(flag)
        {
            for(int i=1;i<=5;i++)
            {
                printf("%c",a[i][1]);
                for(int j=2;j<=5;j++)
                    printf(" %c",a[i][j]);
                printf("\n");
            }
        }
        memset(a,0,sizeof(a));
    }
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章