码迷,mamicode.com
首页 > 其他好文 > 详细

UVA 227

时间:2015-12-23 12:35:15      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:

这道题虽然思路简单,但是想要A却不简单,因为对格式的要求比较让人头疼

#include <iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string>
#include<string.h>
#include<set>
using namespace std;
int main()
{
  int n,si,sj,flag,visi;
  char m[6][8];
  int num=0;
  while(gets(m[0])){
        num++;
        flag=-1;
        visi=-1;
        if(strcmp(m[0],"Z")==0)
            return 0;
        gets(m[1]);
        gets(m[2]);
        gets(m[3]);
        gets(m[4]);
        for(int i=0;i<5;i++){
        for(int j=0;j<5;j++){
            if(m[i][j]== ){
                si=i;sj=j;
                 i=5;j=5;
            }
        }
        }


   char s [1000];
    bool exit_koro = false;
  while( !exit_koro&&gets(s)){
    for(int i=0;i<strlen(s);i++){
            if(s[i]==0||visi==1){
                exit_koro=true;
                break;
            }

        if(s[i]==A){
            if(si-1<0){
            visi=1;
          }
        else{
                m[si][sj]=m[si-1][sj];
                m[si-1][sj]= ;
                si=si-1;
        }
        }
        if(s[i]==B){
                if(si+1>=5){
                   visi=1;

                }
                else{
            m[si][sj]=m[si+1][sj];
            m[si+1][sj]= ;
            si=si+1;

                }
        }
        if(s[i]==R){
            if(sj+1>=5){
             visi=1;
            }
            else{
            m[si][sj]=m[si][sj+1];
            m[si][sj+1]= ;
            sj=sj+1;
            }
        }
        if(s[i]==L){
            if(sj-1<0){
              visi=1;

            }
            else{
            m[si][sj]=m[si][sj-1];
            m[si][sj-1]= ;
            sj=sj-1;

            }
        }

    }
  }
         if(num>1)
          printf("\n");
        if(visi==-1){
        printf("Puzzle #%d:\n",num);
        for(int i=0;i<5;i++){
           printf ("%c %c %c %c %c\n",m[i][0],m[i][1],m[i][2],m[i][3],m[i][4]);
        }
    }
   else{
         printf("Puzzle #%d:\n",num);
              printf("This puzzle has no final configuration.\n");

    }
    //打出空行!!


  }

   return 0;
     }

 

UVA 227

标签:

原文地址:http://www.cnblogs.com/wintersong/p/5069173.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!