鱼C论坛

 找回密码
 立即注册
查看: 4585|回复: 1

[已解决]邻接矩阵的基本运算代码

[复制链接]
发表于 2021-6-4 20:12:45 | 显示全部楼层 |阅读模式

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

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

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

  3. typedef int ElemType;

  4. #define MAXV 20
  5. #define INF 32767


  6. typedef struct//顶点
  7. {
  8.         char no;
  9.     ElemType data;
  10. }VertexType;

  11. typedef struct//邻接矩阵数组
  12. {
  13.         int edges[MAXV][MAXV];   //邻接矩阵数组
  14.         int n,e;                 //顶点数,边数
  15.     VertexType vexs[MAXV];   //顶点信息
  16. }MatGraph;



  17. //创建图的运算算法
  18. void CreateAdj(MatGraph *G)//创建图的邻接矩阵
  19. {
  20.   G=(MatGraph *)malloc(sizeof(MatGraph));
  21.   int i=0,j=0;
  22.   printf("请输入邻接矩阵的顶点数和边数:\n");
  23.   scanf("%d",&G->n);
  24.   scanf("%d",&G->e);

  25.   printf("请输入邻接矩阵的顶点信息:\n");
  26.   while(i<G->n)
  27.   {
  28.     scanf("%c",&G->vexs[i].no);
  29.         i++;
  30.         getchar();
  31.   }
  32.   i=0;

  33.   printf("请输入邻接矩阵:\n");
  34.   while(i<G->n)
  35.   {
  36.     while(j<G->n)
  37.         {
  38.       scanf("%d",&G->edges[i][j]);
  39.           j++;
  40.         }
  41.         j=0;
  42.         i++;
  43.   }
  44. }


  45. //输出图的运算算法
  46. void DispAdj(MatGraph *G)
  47. {
  48.   int i=0,j=0;
  49.   printf("邻接矩阵:\n");
  50.   while(i<G->n)
  51.   {
  52.           while(j<G->n)
  53.           {
  54.          printf("%3d",G->edges[i][j]);
  55.                  j++;
  56.           }
  57.       printf("\n");
  58.           j=0;
  59.           i++;
  60.   }
  61. }


  62. //销毁图的运算算法
  63. void DestroyAdj(MatGraph *G)
  64. {
  65.    free(G);
  66. }



  67. void main()
  68. {
  69.    MatGraph *G;
  70.    CreateAdj(G);
  71.    DispAdj(G);
  72. }
复制代码





在调试时G->n,G->e 出现CXX0030:Error:expression cannot be evpraluated 的提示
最佳答案
2021-6-4 20:57:08
void main()
{
   MatGraph *G;
   CreateAdj(G);
   DispAdj(G);
}
把这里的MatGraph *G;换成MatGraph *G=(MatGraph *)malloc(sizeof(MatGraph));可以解决  就不需要void CreateAdj(MatGraph *G)中的G=(MatGraph *)malloc(sizeof(MatGraph));
如果你就是为了在void CreateAdj(MatGraph *G)申请内存  那就返回值类型改为MatGraph * 然后返回G   
因为你原来void CreateAdj(MatGraph *G)函数中的 G=(MatGraph *)malloc(sizeof(MatGraph));并不会把申请地址传给void main()中的G  所以会导致你DispAdj(G);中的G是个野指针
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-6-4 20:57:08 | 显示全部楼层    本楼为最佳答案   
void main()
{
   MatGraph *G;
   CreateAdj(G);
   DispAdj(G);
}
把这里的MatGraph *G;换成MatGraph *G=(MatGraph *)malloc(sizeof(MatGraph));可以解决  就不需要void CreateAdj(MatGraph *G)中的G=(MatGraph *)malloc(sizeof(MatGraph));
如果你就是为了在void CreateAdj(MatGraph *G)申请内存  那就返回值类型改为MatGraph * 然后返回G   
因为你原来void CreateAdj(MatGraph *G)函数中的 G=(MatGraph *)malloc(sizeof(MatGraph));并不会把申请地址传给void main()中的G  所以会导致你DispAdj(G);中的G是个野指针
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-12 20:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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