鱼C论坛

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

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

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

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

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

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

截取了一部分出来。。可以编译。

  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define MAXVEX 14

  4. //边表结点
  5. typedef struct EdgeNode
  6. {
  7.     int adjvex;
  8.     int weight;
  9.     struct EdgeNode *next;
  10. } EdgeNode;

  11. //顶点表结点
  12. typedef struct VertexNode
  13. {
  14.     int in;
  15.     int data;
  16.     EdgeNode *firstedge;
  17. } VertexNode,AdjList[MAXVEX];

  18. //这个表
  19. typedef struct
  20. {
  21.     AdjList adjList;
  22.     int numVertexes,numEdges;
  23. } graphAdjList,*GraphAdjList;

  24. void CreateALGraph(GraphAdjList GL)
  25. {
  26.     int i;
  27.     EdgeNode *e;
  28.     GL->numEdges = 20;
  29.     GL->numVertexes = 14;
  30.     for(i = 0; i < GL->numVertexes; ++i)
  31.     {
  32.         GL->adjList[i].data = i;
  33.     }
  34. }

  35. int main()
  36. {
  37.     GraphAdjList G;
  38.     CreateALGraph(&G);
  39.     printf("%d",G->numEdges);
  40.     return 0;
  41. }
复制代码
最佳答案
2018-10-12 21:47:31
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define MAXVEX 14


  4. typedef struct Node_of_Edge
  5. {
  6.         int adjvex;
  7.         int weight;
  8.         struct EdgeNode *next;
  9. }EdgeNode;


  10. typedef struct Node_of_Vertex
  11. {
  12.         int in;
  13.         int data;
  14.         EdgeNode *firstedge;
  15. }VertexNode, AdjList[MAXVEX];


  16. typedef struct Adjacent_Graph_List
  17. {
  18.         AdjList adjList;
  19.         int numVertexes, numEdges;
  20. }GraphAdjList;

  21. void CreateALGraph(GraphAdjList ** G)
  22. {
  23.         int i;
  24.         EdgeNode *e;
  25.         *G = (GraphAdjList *)malloc(sizeof(GraphAdjList));
  26.         (*G)->numEdges = 20;
  27.         (*G)->numVertexes = 14;
  28.         for (i = 0; i < (*G)->numVertexes; ++i)
  29.         {
  30.                 (*G)->adjList[i].data = i;
  31.         }
  32. }

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

使用道具 举报

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

  3. #define MAXVEX 14


  4. typedef struct Node_of_Edge
  5. {
  6.         int adjvex;
  7.         int weight;
  8.         struct EdgeNode *next;
  9. }EdgeNode;


  10. typedef struct Node_of_Vertex
  11. {
  12.         int in;
  13.         int data;
  14.         EdgeNode *firstedge;
  15. }VertexNode, AdjList[MAXVEX];


  16. typedef struct Adjacent_Graph_List
  17. {
  18.         AdjList adjList;
  19.         int numVertexes, numEdges;
  20. }GraphAdjList;

  21. void CreateALGraph(GraphAdjList ** G)
  22. {
  23.         int i;
  24.         EdgeNode *e;
  25.         *G = (GraphAdjList *)malloc(sizeof(GraphAdjList));
  26.         (*G)->numEdges = 20;
  27.         (*G)->numVertexes = 14;
  28.         for (i = 0; i < (*G)->numVertexes; ++i)
  29.         {
  30.                 (*G)->adjList[i].data = i;
  31.         }
  32. }

  33. int main()
  34. {
  35.         GraphAdjList *G;
  36.         CreateALGraph(&G);
  37.         printf("%d", G->numEdges);
  38.         return 0;
  39. }
复制代码
暂时能用
想知道小甲鱼最近在做啥?请访问 -> 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, 2024-4-26 15:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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