在C中遍历矩阵时出错

时间:2015-01-01 17:36:10

标签: c++ arrays malloc

以下代码中提到的错误注释是程序停止工作的地方。 我不确定是什么错误。请帮忙。感谢。

#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cstring>

using namespace std;

int print(int *g[],int m,int n)
{
    int i,j;
    for(i=0;i<m;i++)
    {
        for(j=0;j<n;j++)
        {
            printf("Check\n");
            printf("%d\t",g[i][j]);
        }
        printf("\n");
    }
    return 1;
}

int main()
{
    int i,r,c,j;
    printf("Enter Matrix Row\n");
    scanf("%d",&r);
    printf("Enter Matrix Column\n");
    scanf("%d",&c);

    int **s=(int **)malloc(r*sizeof(int*));
    for(i=0;i<r;i++)
        s[i]=(int*)malloc(c*sizeof(int));

    memset(s,0,sizeof(s));

    for(i=0;i<r;i++)
    {
        for(j=0;j<c;j++)
        {
            printf("I will Win\n");

            // Here is the Error

            printf("%d\t",s[i][j]);
        }
        printf("\n");
    }
    //cout<<print((int**)s,r,c);

}

我认为memset应该在这里工作。 在函数内部,遍历也不起作用。

1 个答案:

答案 0 :(得分:2)

memset()将所有位设置为0,在您的情况下,您正在s NULL中创建所有指针。几乎因为sizeof(s)是指针大小而不是指针数组中指针的数量。

如果您需要的是初始化为零,那么应该这样做

int **s=(int **)calloc(r, sizeof(int*));
for(i=0;i<r;i++)
    s[i]=(int*)calloc(c, sizeof(int));