gpt4 book ai didi

c - 来自标准输入的存储行永远不会改变

转载 作者:塔克拉玛干 更新时间:2023-11-03 06:06:38 25 4
gpt4 key购买 nike

我正在处理这个问题 ( Uva227 )。当我测试这些案例时,我几乎收到了正确的结果,但我遇到了一个问题。我使用函数 gets() 从标准输入中获取一行,并将其存储在 a[0] 中。但是在第一个输入矩阵之后,a[0] 再也不会改变了。有什么问题吗?

附言在谜题 #2(即第二个输入矩阵)中,a[0] 没有改变,所以我得到了错误的答案。但如果我把它放在第一位,它会返回正确的输出。所以我认为算法是正确的,但是在读取第一行时出了点问题。

英语不是我的母语;请原谅我的语法错误。

#include <stdio.h>
#include <string.h>

char a[5][5];



int main(){
int _case = 1;
char c;
while(gets(a[0])){//Please focus on this line;it seems that a[0] never changed since first reading.
if(a[0][0] == 'Z') break;
int blank_i, blank_j;
for(int i = 0; i < 5; i++){
if(i) gets(a[i]);
for(int j = 0; j < 5; j++){
if(a[i][j] == ' '){
blank_i = i;
blank_j = j;
}
}
}
bool flag = true;
int i = 0;
while((c = getchar()) != '0'){
switch(c){
case 'A':
a[blank_i][blank_j] = a[blank_i - 1][blank_j];
a[--blank_i][blank_j] = ' '; break;
case 'B':
a[blank_i][blank_j] = a[blank_i + 1][blank_j];
a[++blank_i][blank_j] = ' '; break;
case 'L':
a[blank_i][blank_j] = a[blank_i][blank_j - 1];
a[blank_i][--blank_j] = ' '; break;
case 'R':
a[blank_i][blank_j] = a[blank_i][blank_j + 1];
a[blank_i][++blank_j] = ' '; break;
default: break;
}
}
//add a getchar() here will fix the problem.
printf("Puzzle #%d:\n", _case);
if(blank_i < 0 || blank_i > 4 || blank_j < 0 || blank_j > 4)
printf("This puzzle has no final configuration.\n");
else{
for(int i = 0; i < 5; i++){
for(int j = 0; j < 5; j++){
printf("%c ", a[i][j]);
}
printf("\n");
}
}
printf("\n");
_case++;
}
return 0;
}

最佳答案

您误诊了问题。 “在第一个输入矩阵之后,a[0] 再也不会改变”并不是这种情况。实际问题是,在您读取结束移动列表的 '0' 之后,在下一个拼图开始之前有一个换行符。您的代码没有考虑到这一点,因此将换行符视为下一个拼图第一行的第一个字符。在回到 while 循环的开头之前,通过吞下这个换行符来修复它。

旁白:一些评论者指出您不应该使用 gets。他们是 100% 正确的,但这与这个问题无关,离开它并不能解决这个问题。

关于c - 来自标准输入的存储行永远不会改变,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56411862/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com