C 引用函数中的矩阵以计算邻接矩阵中节点的in度时出错 int节点索引(int*g,int节点){ int i; 整数计数=0; 对于(i=0;i

C 引用函数中的矩阵以计算邻接矩阵中节点的in度时出错 int节点索引(int*g,int节点){ int i; 整数计数=0; 对于(i=0;i,c,nodes,adjacency-matrix,C,Nodes,Adjacency Matrix,您将数组作为参数(g)发送,您需要发送一个2d数组或矩阵,要执行此操作,请将参数从int*g更改为int**g 编辑: 我相信你需要的是这方面的东西 int nodeInDegree(int *g, int node){ int i; int count=0; for(i=0; i<COLUMNS; i++){ if (g[node][i] == 1){ ++count; }

您将数组作为参数(g)发送,您需要发送一个2d数组或矩阵,要执行此操作,请将参数从int*g更改为int**g

编辑: 我相信你需要的是这方面的东西

int nodeInDegree(int *g, int node){
    int i;
    int count=0;

    for(i=0; i<COLUMNS; i++){
            if (g[node][i] == 1){
                    ++count;
            }
    }

    return count;
}
#包括
int节点索引(int*g)
{
int i;
整数计数=0;
对于(i=0;i<5;i++)
如果(g[i]==1)+计数;
返回计数;
}
int main()
{
int mat[5][5]={{1,0,1,0,0},
{1, 0, 1, 0, 0},
{1, 0, 1, 0, 0},
{1, 0, 1, 0, 0},
{1, 0, 1, 0, 0}};
printf(“%d\n”,节点索引(&mat[0]);
返回0;
}

这个错误似乎不言自明。
int*g
相当于
int g[]
,因此它是一个1D数组,但您试图像访问2D数组一样访问它。显示调用方作为参数
g
传递的内容的声明。事实上,欢迎使用堆栈溢出。请尽快阅读该页面,并访问描述和(MCVE)的链接。提供必要的详细信息,包括您的MCVE、编译器警告和相关错误(如果有),将允许这里的每个人帮助您解答您的问题。我的教授编写了一个模板,他们就是这样编写的,所以我整个时间都没有质疑它。我只是测试了一下,发现了一个seg错误。基本上,它们初始化了d使用g_检验[5][5]建立矩阵,并通过表示nodeInDegree引用它(&g_检验,i)您的矩阵是在堆栈中启动的,因此将整个矩阵传递给函数将不起作用,您应该在函数调用中只传递矩阵的一个数组,而不是将节点作为参数传递,尝试更改函数,使其只接收对应于该节点的数组。类似于
nodeInDegree(&g[node])
g_test是声明为全局变量还是在main内部?
#include <stdio.h>
int nodeInDegree(int *g)
{
    int i;
    int count = 0;
    for (i = 0; i < 5; i++)
        if (g[i] == 1) ++count;
    return count;
}

int main()
{
    int mat[5][5] = {{1, 0, 1, 0, 0},
                     {1, 0, 1, 0, 0},
                     {1, 0, 1, 0, 0},
                     {1, 0, 1, 0, 0},
                     {1, 0, 1, 0, 0}};
    printf("%d\n", nodeInDegree(&mat[0]));

    return 0;
}