关闭

第十二周项目二 输出出图G中每个顶点的出度

标签: 算法数据结构
374人阅读 评论(0) 收藏 举报
分类:
/*
* Copyright (c) 2015, 烟台大学计算机与控制工程学院
* All rights reserved.
* 文件名称: main.cpp,graph.h,graph.cpp
* 作者:巩凯强
* 完成日期:2015年11月19日
* 版本号:codeblocks
*
* 问题描述:  输出出图G中每个顶点的出度
* 输入描述: 无
* 程序输出: 见运行结果
*/
#ifndef GRAPH_H_INCLUDED
#define GRAPH_H_INCLUDED
#include <stdio.h>
#include <malloc.h>
#define MAXV 100                //最大顶点个数
#define INF 32767       //INF表示∞
typedef int InfoType;

//以下定义邻接矩阵类型
typedef struct
{
    int no;                     //顶点编号
    InfoType info;              //顶点其他信息,在此存放带权图权值
} VertexType;                   //顶点类型

typedef struct                  //图的定义
{
    int edges[MAXV][MAXV];      //邻接矩阵
    int n,e;                    //顶点数,弧数
    VertexType vexs[MAXV];      //存放顶点信息
} MGraph;                       //图的邻接矩阵类型

//以下定义邻接表类型
typedef struct ANode            //弧的结点结构类型
{
    int adjvex;                 //该弧的终点位置
    struct ANode *nextarc;      //指向下一条弧的指针
    InfoType info;              //该弧的相关信息,这里用于存放权值
} ArcNode;

typedef int Vertex;

typedef struct Vnode            //邻接表头结点的类型
{
    Vertex data;                //顶点信息
    int count;                  //存放顶点入度,只在拓扑排序中用
    ArcNode *firstarc;          //指向第一条弧
} VNode;

typedef VNode AdjList[MAXV];    //AdjList是邻接表类型

typedef struct
{
    AdjList adjlist;            //邻接表
    int n,e;                    //图中顶点数n和边数e
} ALGraph;                      //图的邻接表类型

//功能:由一个反映图中顶点邻接关系的二维数组,构造出用邻接矩阵存储的图
//参数:Arr - 数组名,由于形式参数为二维数组时必须给出每行的元素个数,在此将参数Arr声明为一维数组名(指向int的指针)
//      n - 矩阵的阶数
//      g - 要构造出来的邻接矩阵数据结构
void ArrayToList(int *Arr, int n, ALGraph *&); //用普通数组构造图的邻接表

int OutDegree(ALGraph *G,int v);
void OutDs(ALGraph *G);
#endif // GRAPH_H_INCLUDED


#include "graph.h"
void ArrayToList(int *Arr, int n, ALGraph *&G)
{
    int i,j,count=0;  //count用于统计边数,即矩阵中非0元素个数
    ArcNode *p;
    G=(ALGraph *)malloc(sizeof(ALGraph));
    G->n=n;
    for (i=0; i<n; i++)                 //给邻接表中所有头节点的指针域置初值
        G->adjlist[i].firstarc=NULL;
    for (i=0; i<n; i++)                 //检查邻接矩阵中每个元素
        for (j=n-1; j>=0; j--)
            if (Arr[i*n+j]!=0)      //存在一条边,将Arr看作n×n的二维数组,Arr[i*n+j]即是Arr[i][j]
            {
                p=(ArcNode *)malloc(sizeof(ArcNode));   //创建一个节点*p
                p->adjvex=j;
                p->info=Arr[i*n+j];
                p->nextarc=G->adjlist[i].firstarc;      //采用头插法插入*p
                G->adjlist[i].firstarc=p;
            }

    G->e=count;
}
//返回图G中编号为v的顶点的出度
int OutDegree(ALGraph *G,int v)
{
    ArcNode *p;
    int n=0;
    p=G->adjlist[v].firstarc;
    while (p!=NULL)
    {
        n++;
        p=p->nextarc;
    }
    return n;
}

//输出图G中每个顶点的出度
void OutDs(ALGraph *G)
{
    int i;
    for (i=0; i<G->n; i++)
        printf("  顶点%d:%d\n",i,OutDegree(G,i));
}

#include "graph.h"
int main()
{
    ALGraph *G;
    int A[7][7]=
    {
        {0,1,1,1,0,0,0},
        {0,0,0,0,1,0,0},
        {0,0,0,0,1,1,0},
        {0,0,0,0,0,0,1},
        {0,0,0,0,0,0,0},
        {0,0,0,1,1,0,1},
        {0,1,0,0,0,0,0}
    };
    ArrayToList(A[0], 7, G);
    printf("(1)各顶点出度:\n");
    OutDs(G);
    return 0;
}

运行结果:


知识点总结:

运用图的基本运算,调用函数OutDegree()实现该功能。

学习心得:

找到一种适合自己的学习方法,理解算法最重要。

1
0
查看评论

第十二周--数据结构--输出出图G中每个顶点的出度

/*   *第十一周--数据结构--输出出图G中每个顶点的出度   *Copyright (c) 2015 烟台大学计算机与控制工程学院   *All right reserved.   *文件名称:   *writer:罗海员   *da...
  • Sailor_luo
  • Sailor_luo
  • 2015-11-27 08:42
  • 696

数据结构实践——操作用邻接表存储的图

本文是针对[数据结构基础系列(7):图]的实践。【项目 - 操作用邻接表存储的图】 假设图G采用邻接表存储,分别设计实现以下要求的算法: (1)输出出图G中每个顶点的出度; (2)求出图G中出度最大的一个顶点,输出该顶点编号; (3)计算图G中出度为0的顶点数; (4)判断图G中是否存在边...
  • sxhelijian
  • sxhelijian
  • 2015-11-08 11:30
  • 2424

图的邻接矩阵表示法及顶点入度、出度的计算方法

设图(graph)的结构为:         下面,我们来建立这个图, 并求出各个顶点的入度和出度,程序如下: #include #define MAX_VERTEX 20 // 最大顶点数 #define VERTEX 4 // 实际顶点数...
  • stpeace
  • stpeace
  • 2013-06-12 13:15
  • 16839

数据结构:不带权有向图的邻接矩阵和邻接表储存及求出入度实现

14.假设不带权有向图采用邻接矩阵G存储,设计实现以下功能的算法。 (1) 求出图中每个顶点的入度。 (2)求出图中每个顶点的出度。 (3)求出图中出度为0的顶点数。 15. 假设不带权有向图采用邻接表G存储,设计实现以下功能的算法。 (1) 求出图中每个顶点的入度。 (2)求出图中每个...
  • qq_39805477
  • qq_39805477
  • 2017-11-28 23:19
  • 727

图的实现—邻接矩阵(求出各顶点的出度和入度)

//以邻接矩阵实现求图各定点出度和入度 //姊妹篇邻接表实现求图各点的出度和入度 #include #include #define MAX 200 int main() { int Vexs,Edges;//顶点和边数 int m,n; int p,q;//弧尾p,弧头q int id...
  • yuzibode
  • yuzibode
  • 2014-01-16 15:38
  • 2104

第十二周 求出图G中出度最大的一个顶点,输出该顶点编号

/* * Copyright (c) 2015, 烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称: main.cpp,top.h,1.cpp * 作者:于东林 * 完成日期:2015年12月30日 * 版本号:codeblocks * * 问...
  • ydl197791
  • ydl197791
  • 2015-12-30 19:39
  • 691

用邻接表存储有向图,并输出各顶点的出入和入度

#include #include #define MAX_LENGTH 100 struct ArcNode {     int adjvex;//有向边的另一个邻接点的序号     struc...
  • yf0994
  • yf0994
  • 2014-09-17 08:40
  • 2945

图的m种着色方案

图的m着色 描述 Description 【问题描述】   给定无向连通图G和m种不同的颜色。用这些颜色为图G的各顶点着色,每个顶点着一种颜色。如果有一种着色法使G中每条边的2个顶点着不同颜色,则称这个图是m可着色的。图的m着色问题是对于给定图G和m种颜色,找出所有不同的着色法。 【...
  • uiqrm
  • uiqrm
  • 2017-01-24 21:22
  • 397

第十二周项目二 (2)求出图G中出度最大的一个顶点,输出该顶点编号

/* * Copyright (c) 2015, 烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称: main.cpp,graph.h,graph.cpp * 作者:巩凯强 * 完成日期:2015年11月19日 * 版本号:codeblocks * * 问题描...
  • gkq_comeon
  • gkq_comeon
  • 2015-11-19 19:47
  • 428

第十周到第十二周总结

有好几周没有上网了!在这几周了经历了许多第一次! 1。第一次参加同学的生日PARTY,而且是玩通宵!大学最后一次了,就让自己玩得疯狂一点啦! 2。我第一次穿起了学士服,我们已经照了毕业照了! 哈哈,真是穿起龙袍也不象太子!轮到我们班时,我还忘了照个人照呢,害得自己说了一个谎,才补了回来!失败...
  • longmen23
  • longmen23
  • 2005-11-18 16:53
  • 609
    个人资料
    • 访问:34200次
    • 积分:1243
    • 等级:
    • 排名:千里之外
    • 原创:87篇
    • 转载:0篇
    • 译文:0篇
    • 评论:21条
    文章分类
    最新评论