在c中将矩阵文本文件读入数组

时间:2016-03-16 12:57:32

标签: c

我已经开始学习使用C语言编写代码了,我被困在一项任务中,我应该读取文件,将内容放入矩阵中,最后打印矩阵。

输入文件包含:

    ------01-1
    1--------1
    --0-1-----
    ----0-----
    ------0--1
    -----1--1-
    ------0--0
    0---------
    --11-----1
    0-1-----0-

这是我到目前为止编写的代码:

int main()
{   
    FILE *filename = fopen("file.txt","r");
    int matrix[10][10];
    int c;

    for(int i =0; i < 10; i++)
    {
        for(int j=0; j<10; j++)
        {
            c = fgetc(filename);
            if(c == '1')
            {
                matrix[i][j] = 1;
            }
            else if(c == '0')
            {
                matrix[i][j] = 0;
            }
        }
    }

    for(int a = 0; a < 10; a++)
    {
        for(int  b = 0; b < 10; b++)
        {
            printf("%d", matrix[a][b]);
        }
        printf("\n");
    }

}

输出:

-520092443803-520092443-12480181
2686620131463841127199806539638031616085
1316435226866683164344001-520092443011
51119868016113146336314633624404833019927382943080192
26869241998418816-1123324798-2268660019980688424308334426866161992765860
0019927658711830833442686648199276586030801920
1-8756571168119980461561998099927-13626866284
0175821461101992769785308335604200816026866681992735205
199343520826867321992749998819927700401992769850-875656752419907241990720
11268674426869241992847904-1121896548-2119927710210

Press any key to continue.

我对输出的猜测是它没有将c值添加到矩阵中。所以它打印出一个空的&#34;阵列;空数组导致奇怪的数字?

我知道我正在从文本文件中读取字符。所以我需要将它们转换为int值。

但为什么我的代码出错了?哪里出错?

1 个答案:

答案 0 :(得分:0)

初始化矩阵

int matrix[10][10] = {0};

处理0和1以外的输入

我们还需要处理什么:

  1. 连字符或-输入:为ex:2或-1
  2. 保存其他一些数字
  3. EOF或文件结尾:结束程序或类似处理
  4. 新行,尾随空格或其他未知字符:忽略该字符并再次阅读
  5. c = fgetc(filename);
    if(c == '1')
    {
       matrix[i][j] = 1;
    }
    else if(c == '0')
    {
        matrix[i][j] = 0;
    }
    else if(c == '-')
    {
        matrix[i][j] = -1;  /* Special number for - */
    }
    else if(c == EOF)
    {
        return -1; /* End of file handling */
    }
    else
    {
       --j; /* Ignore this character and enter into loop again */
       /* Although modifying loop controlling var inside is not a good habit */
       /* For this small module, it should be fine */
    }