鱼C论坛

 找回密码
 立即注册
查看: 3582|回复: 0

[学习笔记] 数据结构图

[复制链接]
发表于 2017-12-16 23:14:07 | 显示全部楼层 |阅读模式

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

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

x
#include<stdio.h>
#define MAX 20
typedef struct
{
        char vexs[MAX];//顶点向量
        int arcs[MAX][MAX];// 邻接矩阵
        int vexnum,arcnum;//图的当前顶点数和边数
}Graph;
int Locatevex(Graph G,char v)//定位函数 ,寻找顶点的位置
{
        int i;
        for(i=0;i<G.vexnum;i++)
        if(G.vexs[i]==v)
                return i;
        return -1;
}
void CreateGreph(Graph &G,int visited[20])//创建有向图
{
        int i,j,w,m,n;   
        char a,b,c;
        printf("请输入图G的顶点数和弧数:");
        scanf("%d %d",&G.vexnum,&G.arcnum);
        for(i=0;i<G.vexnum;i++)
        visited[i]=0; //初始数组为0
        for(i=0;i<G.vexnum;i++)//将顶点向量存入vex矩阵
        {
                printf("请输入第%d个顶点信息:",i+1);
                scanf(" %c",&G.vexs[i]);
                getchar();
        }
        for(i=0;i<G.vexnum;i++) //初始化邻接矩阵
        {
                for(j=0;j<G.vexnum;j++)
                {
                        G.arcs[i][j]=0;               
                }
        }
        for(i=0;i<G.arcnum;i++)
        {
                printf("请输入第%d条弧依附的两个顶点及权值:",i+1);
                scanf(" %c %c %d",&a,&b,&w);
                m=Locatevex(G,a);
                n=Locatevex(G,b);
            G.arcs[m][n]=w;
        }
}
void PrintMatrix(Graph G) //输出邻接矩阵
{
        int i,j;  
        int num=0,temp=0;  
        printf("\n由图G生成的邻接矩阵如下:\n");  
        for(i=0;i<G.vexnum;i++)
        {
                for(j=0;j<G.vexnum;++j)   
                printf("%-5d",G.arcs[i][j]);   
                printf("\n");
        }
        printf("各点的度为:\n");  
        for(i=0;i<G.vexnum;i++)
        {
                for(j=0;j<G.vexnum;++j)
                {
                        if(G.arcs[i][j]!=0)         
                        num=num+1;
                }
                printf("%c:",G.vexs[i]);
                printf("%-4d",num);   
                num=0;   
                printf("\n");//无向图输出
        }
        printf("各点度的情况为:\n");  
        for(i=0;i<G.vexnum;i++)
        {
                for(j=0;j<G.vexnum;++j)
                {
                        if(G.arcs[j][i]!=0)         
                        num=num+1;
                }
                for(j=0;j<G.vexnum;++j)
                {
                         if(G.arcs[i][j]!=0)         
                         temp=temp+1;
                }
                printf("%c:",G.vexs[i]);         
                printf("出度为%-2d",temp);   
                printf("入度为%-2d",num);   
                num=0;   
                temp=0;
                printf("\n");//有向图输出
        }
}
int main()
{
        int m;
        int visited[20];
        printf("建立图:\n");
        Graph G;
        CreateGreph(G,visited);
        PrintMatrix(G);
}
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-19 14:03

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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