判断

1-1
无向连通图边数一定大于顶点个数减1。F

1-2
在任一有向图中,所有顶点的入度之和等于所有顶点的出度之和。T

1-3
Prim 算法是通过每步添加一条边及其相连的顶点到一棵树,从而逐步生成最小生成树。T

1-4
如果无向图G必须进行两次广度优先搜索才能访问其所有顶点,则G一定有2个连通分量。T

1-5
用邻接矩阵法存储图,占用的存储空间数只与图中结点个数有关,而与边数无关。T

1-6
Kruskal 算法是通过每步添加一条边及其相连的顶点到一棵树,从而逐步生成最小生成树。F

1-7
在一个有向图中,所有顶点的入度与出度之和等于所有边之和的2倍。T

1-8
无向连通图至少有一个顶点的度为1。F

1-9
Prim 算法是维护一个森林,每一步把两棵树合并成一棵。F

1-10
无向连通图所有顶点的度之和为偶数。T

1-11
Kruskal 算法是维护一个森林,每一步把两棵树合并成一棵。T

1-12
用邻接表法存储图,占用的存储空间数只与图中结点个数有关,而与边数无关。F

1-13
用一维数组G[]存储有4个顶点的无向图如下:

G[] = { 0, 1, 0, 1, 1, 0, 0, 0, 1, 0 }

则顶点2和顶点0之间是有边的。T

选择

2-1
任何一个带权无向连通图的最小生成树( C )
A.有可能不存在
B.是唯一的
C.有可能不唯一
D.是不唯一的

2-2
关于图的邻接矩阵,下列哪个结论是正确的?( A )
A.有向图的邻接矩阵可以是对称的,也可以是不对称的
B.无向图的邻接矩阵可以是不对称的,也可以是对称的
C.有向图的邻接矩阵总是不对称的
D.无向图的邻接矩阵总是不对称的

2-3
我们用一个有向图来表示航空公司所有航班的航线。下列哪种算法最适合解决找给定两城市间最经济的飞行路线问题?( B )
A.Kruskal算法
B.Dijkstra算法
C.深度优先搜索
D.拓扑排序算法

2-4

对下图进行拓扑排序,可以得到不同的拓扑序列的个数是:( B )

networkx有向图权重定义_邻接矩阵


A.2

B.3

C.1

D.4

2-5
对于一个具有N个顶点的无向图,要连通所有顶点至少需要多少条边?( A )
A.N−1
B.N+1
C.N/2
D.N

2-6
在用邻接表表示有N个结点E条边的图时,深度优先遍历算法的时间复杂度为:( B )
A.O(N2 ×E)
B.O(N+E)
C.O(N2)
D.O(N)

2-7
如果从无向图的任一顶点出发进行一次深度优先搜索可访问所有顶点,则该图一定是:( C )
A.有回路的图
B.完全图
C.连通图
D.一棵树

2-8

给定一有向图的邻接表如下。从顶点V1出发按广度优先搜索法进行遍历,则得到的一种顶点序列为:( D )

networkx有向图权重定义_邻接矩阵_02


A.V1,V4,V3,V5,V2

B.V1,V2,V3,V4,V5

C.V1,V2,V3,V5,V4

D.V1,V3,V2,V4,V5

2-9
下面关于图的存储的叙述中,哪一个是正确的?( B )
A.用相邻矩阵法存储图,占用的存储空间数只与图中边数有关,而与结点个数无关
B.用相邻矩阵法存储图,占用的存储空间数只与图中结点个数有关,而与边数无关
C.用邻接表法存储图,占用的存储空间数只与图中边数有关,而与结点个数无关
D.用邻接表法存储图,占用的存储空间数只与图中结点个数有关,而与边数无关

2-10

给定一有向图的邻接表如下。从顶点V1出发按深度优先搜索法进行遍历,则得到的一种顶点序列为:

networkx有向图权重定义_有向图_03


A.V1,V2,V4,V5,V3

B.V1,V2,V3,V5,V4

C.V1,V4,V3,V5,V2

D.V1,V3,V4,V5,V2

2-11
数据结构中Dijkstra算法用来解决哪个问题?( B )
A.关键路径
B.最短路径
C.字符串匹配
D.拓扑排序

2-12

已知一个图的邻接矩阵如下,则从顶点V1出发按深度优先搜索法进行遍历,可能得到的一种顶点序列为:( C )

networkx有向图权重定义_数据结构_04


A.V1,V3,V5,V2,V4,V6

B.V1,V2,V3,V4,V5,V6

C.V1,V2,V4,V5,V6,V3

D.V1,V3,V5,V6,V4,V22-13

使用迪杰斯特拉(Dijkstra)算法求下图中从顶点1到其他各顶点的最短路径,依次得到的各最短路径的目标顶点是:( A )

networkx有向图权重定义_Graph_05


A.5, 2, 3, 6, 4

B.5, 2, 6, 3, 4

C.5, 2, 4, 3, 6

D.5, 2, 3, 4, 62-14

已知一个图的邻接矩阵如下,则从顶点V1出发按广度优先搜索法进行遍历,可能得到的一种顶点序列为:( C )

networkx有向图权重定义_有向图_06


A.V1,V3,V5,V6,V4,V2

B.V1,V2,V4,V5,V6,V3

C.V1,V2,V3,V5,V4,V6

D.V1,V3,V5,V2,V4,V6

2-15
图的广度优先遍历类似于二叉树的:( B )
A.后序遍历
B.层次遍历
C.先序遍历
D.中序遍历

2-16
一个有N个顶点的强连通图至少有多少条边?( A )
A.N
B.N−1
C.N(N−1)
D.N+1

2-17

给定一个有向图的邻接表如下图,则该图有__个强连通分量。( A )

networkx有向图权重定义_邻接矩阵_07


A.3 {{2}, {4}, {0, 1, 3, 5}}

B.1 {0, 1, 2, 3, 4, 5}

C.1 {0, 5, 1, 3}

D.4 {{0, 1, 5}, {2}, {3}, {4}}2-18

给定有权无向图的邻接矩阵如下,其最小生成树的总权重是:( A )

networkx有向图权重定义_networkx有向图权重定义_08


A.14

B.11

C.12

D.10

2-19
对于有向图,其邻接矩阵表示比邻接表表示更易于:( A )
A.求一个顶点的入度
B.求一个顶点的出边邻接点
C.进行图的广度优先遍历
D.进行图的深度优先遍历

2-20

使用迪杰斯特拉(Dijkstra)算法求下图中从顶点1到其他各顶点的最短路径,依次得到的各最短路径的目标顶点是:( B )

networkx有向图权重定义_networkx有向图权重定义_09


A.2, 4, 3, 6, 5, 7

B.6, 7, 5, 3, 2, 4

C.6, 2, 5, 7, 3, 4

D.2, 3, 4, 5, 6, 7

2-21
设N个顶点E条边的图用邻接表存储,则求每个顶点入度的时间复杂度为:( D )
A.O(N)
B.O(N×E)
C.O(N2)
D.O(N+E)

2-22

下面给出的有向图中,有__个强连通分量。( D )

networkx有向图权重定义_有向图_10


A.5 ({0}, {1}, {2}, {3}, {4})

B.1 ({0,1,2,3,4})

C.1 ({1,2,3,4})

D.2 ({1,2,3,4}, {0})

2-23
在任一有向图中,所有顶点的入度之和与所有顶点的出度之和的关系是:( C )
A.大于等于
B.小于等于
C.相等
D.不确定

程序填空

/*  广度优先遍历邻接矩阵存储的图Graph  */
typedef struct {
    Vertex G[MAX][MAX];
    int Nv;
}Graph;
typedef Graph* MGraph;
typedef struct {
    Vertex *vertex;
    int len;
    int ptr;
    int end;
}queue;
typedef queue* Queue;

/* IsEdge(Graph, V, W)检查<V, W>是否图Graph中的一条边,即W是否V的邻接点。  */
bool IsEdge( MGraph Graph, Vertex V, Vertex W )
{
    return Graph->G[V][W]<INFINITY ? true : false;
}

/* Visited[]为布尔类型全局数组,已经初始化为false */
void BFS ( MGraph Graph, Vertex S, void (*Visit)(Vertex) )
{   
    Queue Q;     
    Vertex V, W;

    Q = CreateQueue( MaxSize ); 
    Visit( S );
    Visited[S] = true; 
    AddQ(Q, S);
    while ( !IsEmpty(Q) ) {
        V = DeleteQ(Q);  
        for( W=0; W<Graph->Nv; W++ ) 
            if ( !Visited[W] && IsEdge(Graph, V, W) ) { 
                Visit( W );
                Visited[W] = true; 
                AddQ(Q, W); 
            }
    } /* while结束*/
}

下列代码的功能是对一个给定的图G执行拓扑排序,其中TopNum[]从1开始记录拓扑序。

void Topsort( Graph G )
{
   Queue Q;
   Vertex V, W;
   NodePtr ptr;
   int counter = 0;

   Q = CreateEmptyQueue(NumVertex);
   for ( V=0; V<G->NumV; V++ )
      if ( Indegree[V] == 0 )
         Enqueue(V, Q);
   while ( !IsEmpty(Q) ){
      V = Dequeue( Q );
      TopNum[V] = ++counter;
      for ( ptr=G->List[V]; ptr; ptr=ptr->Next) {
         W = ptr->Vertex;
         if ( --Indegree[W] == 0 )
            Enqueue(W, Q);
      }
   }
   if ( counter != NumVertex )
      printf("ERROR: Graph has a cycle.\n");
   DisposeQueue(Q);
}