SHAOXIAOJ正在加载中...

1694: 图-用邻接表和栈求解拓扑排序

金币值:2 定数:8 时间限制:1.000 s 内存限制:128 M
正确:8 提交:16 正确率:50.00% 命题人:
点赞量:0 收藏量:0 题目类型:程序 知识点: 数据结构-图

题目描述

拓扑排序,要求图的存储结构用邻接表(建立邻接表时采用头插入法),以栈(不能是其它方式,否则输出的拓扑序列即使正确也可能与测试用例中的输出可能不一样)方式实现。

阅读分析下列程序,编写TopologicalSort()函数代码。


#include <stdio.h>
#include <stdlib.h>

#define MAXVEX 100
#define INFINITY 65535

typedef struct EdgeNode { // 表结点
	
	int adjvex;    // 邻接点域,存储该顶点对应的下标
	int weight;     // 用于存储权值,对于非网图可以不需要
	struct EdgeNode *next; // 链域,指向下一个邻接点
} EdgeNode;

typedef struct VertexNode { // 头结点
	int inDegree; // 顶点入度
	int data; // 顶点域,存储顶点信息
	EdgeNode *firstEdge; // 头指针
} VertexNode;

typedef struct Graph {
	int numNodes, numEdges;
	VertexNode AdjList[MAXVEX];
} GraphAdjList;

void CreateALGraph(Graph &G) {
	int i , j , k ;
	for(i = 0; i < G.numNodes; i++) {
		G.AdjList[i].firstEdge = NULL; // 初始化表的头指针为空
		G.AdjList[i].inDegree = 0; // 初始化顶点的入度为0
	}

	for(k = 0; k < G.numEdges; k++) { // 假设采用头插入法		
		scanf("%d%d", &i, &j) ;
		EdgeNode *p = (EdgeNode *)malloc(sizeof(EdgeNode));
		p->adjvex = j ;
		p->next = G.AdjList[i].firstEdge;
		G.AdjList[i].firstEdge = p;
		G.AdjList[j].inDegree ++; // 编号为j的顶点入度增加1
	}
}

struct stack {
	int* base;
	int* top;
	int maxsize;
};
void init(struct stack &s) {
	s.base=new int[MAXVEX];
	s.top=s.base;
	s.maxsize=MAXVEX;
}
void push(struct stack &s,int e) {
	if(s.top-s.base!=s.maxsize) {
		*s.top=e;
		s.top++;
	}
}
int stackempty(struct stack s) {
	if(s.top==s.base) {
		return 1;
	}
	return 0;
}
void pop(struct stack &s,int &e) {
	if(s.base!=s.top) {
		s.top--;
		e=*s.top;
	}
}

// 拓扑排序,输出拓扑排序序列,如果G没有回路并返回1,否则返回0。
int TopologicalSort(GraphAdjList G) {
	struct stack s;
	init(s);
	int count=0;
	for(int i=0; i<G.numNodes; i++) {
		
	}
	while(stackempty(s)==0) {
		int u;
		pop(s,u);
		printf("%d ",u);
		count++;
		EdgeNode *p = G.AdjList.firstEdge; //这里添加数组u,我也不知道为什么会出现下划线。。。
		while(p!=NULL) {
			
		}
	}
	printf("\n");
	if(count<G.numNodes) return 0;
	else return 1;
}

int main(void) {
	GraphAdjList G;
	scanf("%d %d",&G.numNodes,&G.numEdges);
	CreateALGraph(G);
	int result = TopologicalSort(G);
	if (result==1) printf("No Cycle\n");
	else printf("Cycle\n");
	return 0;
}


输入格式

第1行输入两个整数,分别表示图中的顶点数n和边数m 
第2-m+1行每行输入两个整数i和j,表示编号为i的顶点和编号为j的顶点之间有一条边(顶点编号从0开始)

输出格式

1行输出一个拓扑序列,每两个顶点编号之间用空格隔开。
2行输出一个字符串No Cycle(如果原有向图中没有环)或者Cycle(如果原有向图有环)

输入样例    复制

3 3
0 1
0 2
1 2

输出样例    复制

0 1 2
No Cycle