【问题标题】:Reading a matrix using scanf使用 scanf 读取矩阵
【发布时间】:2022-12-19 01:05:42
【问题描述】:

我想从用户那里接收一个矩阵,如下例

6 5
*###**
##***#
##*###
##*###
#**###

这是我的代码:

#include <stdio.h>

int main()
{
    int n, m;
    scanf("%d %d\n", &n, &m);
    char list[n][m];
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            scanf("%c", &list[i][j]);
            
        }
    }

    for(int i=0;i<n;i++)
    {
        for(int j =0;j<m;j++)
        {
            printf("%c",list[i][j]);
        }
    }
    return 0;
}

但是它不是我给它的输入,而是给我如下的输出

*###**
##***#
##*###
##*###
#*

我认为问题在于每行之后的空格被保存为一个字符。谁能帮我?

【问题讨论】:

    标签: c scanf


    【解决方案1】:

    这里有几个问题。

    • 虽然您认为您的输入可能是一个 6x5 矩阵,但 C 没有这样的概念,它只知道数组维度,而程序员必须定义哪个维度对应什么。也就是说,您可以执行char list[n][m];char list[m][n];

      由于您每行读取 6 个字符,并且是从对应于数组最右侧维度的内部循环中读取的,因此您必须提供输入 5 6 或将数组更改为 [m][n]

    • 每当用户按回车键时,scanf 都会在stdin 中留下新行 字符。这些必须被阅读或丢弃。 %d 输入忽略它们,因为它们不是数字,但 %c 然后读取。这是每个学习 C 的人都在努力解决的问题,请参阅scanf() leaves the newline character in the buffer

      您的输出看起来很有趣的原因是因为循环中的 scanf("%c" 不断读取 ' ' 字符并将它们存储在数据中。但是那里没有空间存放它们。由于 4 个读取 存储在数据中,因此您最终少了 4 个字符。然后在读取所有实际数据之前循环结束。

    至于如何修复它,最好的解决办法是忘记你曾经听说过scanf,而改用fgets。学习控制台 I/O 和 stdio.h 的所有细节一般来说是不值得花时间的。

    简单快捷的解决方案是在进行时简单地丢弃所有换行符,然后将换行符与数据分开打印。您可以使用 scanf(" "); 或仅通过单个 getchar() 丢弃换行符,要么将换行符吞掉。


    使用5 6作为输入的固定程序:

    #include <stdio.h>
    
    int main()
    {
        int n, m;
        scanf("%d%d
    ", &n, &m);
        char list[n][m];
    
        for (int i = 0; i < n; i++)
        {
            for (int j = 0; j < m; j++)
            {
                scanf("%c", &list[i][j]);
            }
            scanf("
    "); // discard line feed
        }
    
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<m;j++)
            {
                printf("%c",list[i][j]);
            }
            printf("
    "); // print line feed explicitly
        }
        return 0;
    }
    

    【讨论】:

    • 不要使用scanf(" "); 这不仅会丢弃换行符,还会继续等待另一个非空白字符。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2017-08-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-04-06
    • 1970-01-01
    • 2013-07-04
    相关资源
    最近更新 更多