鱼C论坛

 找回密码
 立即注册
查看: 2459|回复: 3

[已解决]关于用邻接表创建图的问题

[复制链接]
发表于 2018-10-12 21:05:18 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
程序运行了一会,但什么都没显示

截取了一部分出来。。可以编译。
#include <stdio.h>
#include <stdlib.h>

#define MAXVEX 14

//边表结点
typedef struct EdgeNode
{
    int adjvex;
    int weight;
    struct EdgeNode *next;
} EdgeNode;

//顶点表结点
typedef struct VertexNode
{
    int in;
    int data;
    EdgeNode *firstedge;
} VertexNode,AdjList[MAXVEX];

//这个表
typedef struct
{
    AdjList adjList;
    int numVertexes,numEdges;
} graphAdjList,*GraphAdjList;

void CreateALGraph(GraphAdjList GL)
{
    int i;
    EdgeNode *e;
    GL->numEdges = 20;
    GL->numVertexes = 14;
    for(i = 0; i < GL->numVertexes; ++i)
    {
        GL->adjList[i].data = i;
    }
}

int main()
{
    GraphAdjList G;
    CreateALGraph(&G);
    printf("%d",G->numEdges);
    return 0;
}
最佳答案
2018-10-12 21:47:31
#include <stdio.h>
#include <stdlib.h>

#define MAXVEX 14


typedef struct Node_of_Edge
{
        int adjvex;
        int weight;
        struct EdgeNode *next;
}EdgeNode;


typedef struct Node_of_Vertex
{
        int in;
        int data;
        EdgeNode *firstedge;
}VertexNode, AdjList[MAXVEX];


typedef struct Adjacent_Graph_List
{
        AdjList adjList;
        int numVertexes, numEdges;
}GraphAdjList;

void CreateALGraph(GraphAdjList ** G)
{
        int i;
        EdgeNode *e;
        *G = (GraphAdjList *)malloc(sizeof(GraphAdjList));
        (*G)->numEdges = 20;
        (*G)->numVertexes = 14;
        for (i = 0; i < (*G)->numVertexes; ++i)
        {
                (*G)->adjList[i].data = i;
        }
}

int main()
{
        GraphAdjList *G;
        CreateALGraph(&G);
        printf("%d", G->numEdges);
        return 0;
}
暂时能用
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-10-12 21:47:31 | 显示全部楼层    本楼为最佳答案   
#include <stdio.h>
#include <stdlib.h>

#define MAXVEX 14


typedef struct Node_of_Edge
{
        int adjvex;
        int weight;
        struct EdgeNode *next;
}EdgeNode;


typedef struct Node_of_Vertex
{
        int in;
        int data;
        EdgeNode *firstedge;
}VertexNode, AdjList[MAXVEX];


typedef struct Adjacent_Graph_List
{
        AdjList adjList;
        int numVertexes, numEdges;
}GraphAdjList;

void CreateALGraph(GraphAdjList ** G)
{
        int i;
        EdgeNode *e;
        *G = (GraphAdjList *)malloc(sizeof(GraphAdjList));
        (*G)->numEdges = 20;
        (*G)->numVertexes = 14;
        for (i = 0; i < (*G)->numVertexes; ++i)
        {
                (*G)->adjList[i].data = i;
        }
}

int main()
{
        GraphAdjList *G;
        CreateALGraph(&G);
        printf("%d", G->numEdges);
        return 0;
}
暂时能用
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-10-13 16:34:30 | 显示全部楼层

Soga..还要申请空间..thx!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-10-13 16:36:36 | 显示全部楼层
chinggggg 发表于 2018-10-13 16:34
Soga..还要申请空间..thx!

嗯,因为你原本的 GraphAdjList G 是指针,哪能存储那么多东西?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-24 09:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表