首页 > 解决方案 > scanf() 改变矩阵索引的值

问题描述

#include <stdio.h>

int main() {
int i, j, vet [1][1];

for (i=0; i<2; i++){
    for (j=0; j<2; j++){
        scanf ("%d", &vet[i][j]); //input values for each position
        printf("\nvet[%d][%d] = %d", i, j, vet[i][j]); //print the entire matrix
    }
    printf("\n");
}
return 0;
}

输入:

1 2 3 4 5 6 7 8 9

输出:

1 2 3

4 5 6

7 8 0

该代码将 9 的值归因于 'j' 而不是 vet [ i ][ j ],这将对应于 vet [2][2]。因此,我在最后一个打印项目中得到了 vet [2][9] = 0。为什么会发生这种情况?

标签: carrays

解决方案


对于像这样定义的数组

 int vet [1][1];

唯一有效的索引是0,即vet[0][0]。使用索引值 1 会使访问越界。因此,在内循环的第二次迭代中,对于外循环的第一次迭代,您试图访问超出限制的内存,这会调用未定义的行为。然后,行为是 - 好吧,未定义。如果有的话,你不能证明输出是合理的。

如果您想要一个包含 2 个成员的数组,您必须将定义更改为

int vet [2][2];

注意:建议更改数组维度,否则,如果您只有一个元素,则循环本身没有意义。您当然可以通过使循环终止条件i < 1and使代码有效j < 1,但在这种情况下,循环将变得毫无意义。


推荐阅读