首页 > 代码库 > UVA 227 Puzzle - 输入输出
UVA 227 Puzzle - 输入输出
题目:
acm.hust.edu.cn/vjudge/roblem/viewProblem.action?id=19191
这道题本身难度不大,但输入输出时需要特别小心,一不留神就会出问题。
对于输入,如果要读入一行时:
没有空白字符,则直接使用scanf和%s即可;
有空白字符,使用gets,但要小心溢出;fgets一直不能正常工作,有待研究(gets会将缓冲区多余的\n扔掉,fgets会保留在字符串中);
对于要读入单个字符时:
使用scanf和“ %c”进行舍弃空白字符(注意空格),并且最后需要getchar来吃掉最后的回车;
scanf和“%c”会读入空白字符,和getchar相同。
我心中的理想代码如下:
1 #include<stdio.h> 2 #include<string.h> 3 const int LEN=5; 4 const int MAX=100; 5 const int y[]={0,0,1,-1}; 6 const int x[]={-1,1,0,0}; 7 char map[LEN][LEN]; 8 int tra[110]; 9 bool legal(int pos){10 return 0<=pos&&pos<LEN;11 }12 void Pmap(){13 for(int cow=0;cow<LEN;cow++){14 printf("%c",map[cow][0]);15 for(int col=1;col<LEN;col++)16 printf(" %c",map[cow][col]);17 printf("\n");18 }19 }20 int main(){21 tra[‘A‘]=0;22 tra[‘B‘]=1;23 tra[‘R‘]=2;24 tra[‘L‘]=3;25 26 bool first=true;27 int Case=0;28 //freopen("in","r",stdin);29 //freopen("out","w",stdout);30 int bx,by;31 while(gets(map[0])){32 if(map[0][0]==‘Z‘)break;33 for(int col=1;col<LEN;col++)34 gets(map[col]);35 for(int i=0;i<LEN;i++)36 for(int j=0;j<LEN;j++)37 if(map[i][j]==‘ ‘){38 bx=i;by=j;39 }40 bool ok=true;41 char c;42 while(scanf(" %c",&c),c!=‘0‘){43 if(!ok)continue;44 int nx=bx+x[tra[c]],ny=by+y[tra[c]];45 if(!legal(nx)||!legal(ny)){46 ok=false;47 continue;48 }49 map[bx][by]=map[nx][ny];50 map[nx][ny]=‘ ‘;51 bx=nx;by=ny;52 }53 getchar();54 if(first)55 first=false;56 else57 printf("\n");58 printf("Puzzle #%d:\n",++Case);59 if(ok)60 Pmap();61 else62 printf("This puzzle has no final configuration.\n");63 }64 return 0;65 }
UVA 227 Puzzle - 输入输出
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。