在下面的代码中,我试图从文件中读取char并将每个char存储在二维数组中。之后我想用数据坐标(i和j)打印数组中的每个字符:
#include <stdio.h>
#pragma warning(disable:4996)
int main(){
char grid[3][5];
FILE *file;
file = fopen("input.txt", "r");
int c;
if (file == NULL){
perror("Error in reading the file");
}
else{
int j=0;
for (int i = 0; i < 3; i++)
{
while (j<5)
{
grid[i][j] = fgetc(file);
j++;
}
j = 0;
}
}
int length = sizeof grid / sizeof grid[0][0];
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 5; j++)
{
printf("%c %d %d \n", grid[i][j], i, j);
}
}
printf("\n");
return 0;
}
我读的文件如下:
ABCDE
FGHIJ
KLMNO
我希望结果如下:
A 0 0
B 0 1
...
但我得到的真实结果是:
A 0 0
B 0 1
C 0 2
D 0 3
E 0 4
1 0
F 1 1
G 1 2
H 1 3
I 1 4
J 2 0
2 1
K 2 2
L 2 3
M 2 4
如您所见,第二行首先打印空格,第三行打印相同。此外,不打印最后两个字母N和O.有人可以帮我解决这个问题吗?
答案 0 :(得分:2)
更改此位代码
for (int i = 0; i < 3; i++)
{
while (j<5)
{
grid[i][j] = fgetc(file);
j++;
}
j = 0;
}
添加if语句,该语句将检查以确保其读入的字符不是换行符\n
。完成的代码如下所示:
for (int i = 0; i < 3; i++)
{
while (j<5)
{
char c = fegetc(file);
if(c != '\n')
{
grid[i][j] = fgetc(file);
j++;
}
}
j = 0;
}
Fiddling Bits建议将内循环更改为for循环(为了便于阅读)。我同意,但它确实有缺点,必须将j--
放在if语句的else部分,而不是甚至不需要else语句。您可以查看上面的修复程序,并将此内部循环更改为for循环,并确定在这种情况下您认为哪一个具有最佳可读性。此代码表示该更改以及初始问题的修复:
for (int i = 0; i < 3; i++)
{
for(int j = 0; j < 5; j++)
{
char c = fegetc(file);
if(c != '\n')
{
grid[i][j] = fgetc(file);
} else {
j--;
}
}
}
答案 1 :(得分:0)
尝试添加另一个fgetc(文件);在j = 0之后; (没有任何任务)。 它将从您的文件中提取新行char