bec666
bec666
采纳率48%
2019-10-16 18:59

*和&的转化出现了问题?请看代码的注释行,改动前的代码是可以运行的。

25
已采纳

图片说明

#include "stdio.h"    
#include "stdlib.h"   
#include "io.h"  
#include "math.h"  
#include "time.h"

#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
#define MAXVEX 100 

typedef int Status; 
typedef char VertexType; 
typedef int EdgeType; 

typedef struct EdgeNode 
{
    int adjvex;   
    EdgeType info;      
    struct EdgeNode *next; 
}EdgeNode;

typedef struct VertexNode
{
    VertexType data; 
    EdgeNode *firstedge;
}VertexNode, AdjList[MAXVEX];

typedef struct
{
    AdjList adjList; 
    int numNodes,numEdges; 
}GraphAdjList;


void  CreateALGraph(GraphAdjList &G)/*此处将*G改为&G*/
{
    int i,j,k;
    EdgeNode *e;
    printf("输入顶点数和边数:\n");
    scanf("%d,%d",&G.numNodes,&G.numEdges); /* 此处将两个&G->改为&G. */
    for(i = 0;i < G.numNodes;i++) /* 此处将G->改为G. */
    {
        scanf(&G.adjList[i].data);  /* 此处将两个&G->改为&G. */
        G.adjList[i].firstedge=NULL;    /*此处将G->改为G. */
    }


    for(k = 0;k < G.numEdges;k++)/* 此处将G->改为G. */
    {
        printf("输入边(vi,vj)上的顶点序号:\n");
        scanf("%d,%d",&i,&j); 
        e=(EdgeNode *)malloc(sizeof(EdgeNode));
        e->adjvex=j;                                    
        e->next=G.adjList[i].firstedge; /* 此处将G->改为G. */
        G.adjList[i].firstedge=e;       /* 此处将G->改为G. */               

        e=(EdgeNode *)malloc(sizeof(EdgeNode));
        e->adjvex=i;                                       
        e->next=G.adjList[j].firstedge; /* 此处将G->改为G. */
        G.adjList[j].firstedge=e;       /*此处将G->改为G. */               
    }
}

int main(void)
{    
    GraphAdjList G;    
    CreateALGraph(G);/*将&删去*/

    return 0;
}


  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

1条回答

  • caozhy 回答这么多问题就耍赖把我的积分一笔勾销了 2年前

    c语言不支持引用,你将源代码后缀修改为cpp

    #include "stdio.h"    
    #include "stdlib.h"   
    #include <sys/io.h>
    #include "math.h"  
    #include "time.h"
    
    #define OK 1
    #define ERROR 0
    #define TRUE 1
    #define FALSE 0
    #define MAXVEX 100 
    
    typedef int Status; 
    typedef char VertexType; 
    typedef int EdgeType; 
    
    typedef struct EdgeNode 
    {
        int adjvex;   
        EdgeType info;      
        struct EdgeNode *next; 
    }EdgeNode;
    
    typedef struct VertexNode
    {
        VertexType data; 
        EdgeNode *firstedge;
    }VertexNode, AdjList[MAXVEX];
    
    typedef struct
    {
        AdjList adjList; 
        int numNodes,numEdges; 
    }GraphAdjList;
    
    
    void  CreateALGraph(GraphAdjList &G)/*此处将*G改为&G*/
    {
        int i,j,k;
        EdgeNode *e;
        printf("输入顶点数和边数:\n");
        scanf("%d,%d",&G.numNodes,&G.numEdges); /* 此处将两个&G->改为&G. */
        for(i = 0;i < G.numNodes;i++) /* 此处将G->改为G. */
        {
            scanf(&G.adjList[i].data);  /* 此处将两个&G->改为&G. */
            G.adjList[i].firstedge=NULL;    /*此处将G->改为G. */
        }
    
    
        for(k = 0;k < G.numEdges;k++)/* 此处将G->改为G. */
        {
            printf("输入边(vi,vj)上的顶点序号:\n");
            scanf("%d,%d",&i,&j); 
            e=(EdgeNode *)malloc(sizeof(EdgeNode));
            e->adjvex=j;                                    
            e->next=G.adjList[i].firstedge; /* 此处将G->改为G. */
            G.adjList[i].firstedge=e;       /* 此处将G->改为G. */               
    
            e=(EdgeNode *)malloc(sizeof(EdgeNode));
            e->adjvex=i;                                       
            e->next=G.adjList[j].firstedge; /* 此处将G->改为G. */
            G.adjList[j].firstedge=e;       /*此处将G->改为G. */               
        }
    }
    
    int main(void)
    {    
        GraphAdjList G;    
        CreateALGraph(G);/*将&删去*/
    
        return 0;
    }
    

    我这里通过编译。

    点赞 评论 复制链接分享