基于拓扑排序的排课程序

一、题目描述

某学院有n门课程,(i,j)表示课程i是课程j的先行课,及课程i必须在课程j的之前的学期开设。对任意给出的仙子那个课解s={(1,3),(2,4),(3,5),(4,6),(3,7),…},至少需要安排多少个学期?给出每个学期的课程清单。

二、程序思路

分析题目能清楚地发现此题与拓扑排序有很大的关系,拓扑排序的层数就是学期数,每个学期的课程就是每一层的点。所以只需要在拓扑排序的程序上改改就好了。

三、具体实现

int linkedDgraph1::course(int **b)//传入的为保存结果的二维数组
{   
    int number=0;//学期数 
    int n=verticeNumber;//顶点个数 
    int *indegree=new int[num1+1];//顶点的入度数组 
    for(int i=1;i<=num1;i++)//保存入度 
    indegree[i]=inDegree(i);
    stack<int> astack(10000);//声明栈 
    while(n!=0)
    {      int j=0;
         for(int i=1;i<=num1;i++)//遍历将入度为零的点入栈 
        {    
            if(indegree[i]==0)
            { 
              b[number][j++]=i;//保存此点 
              //cout<<i<<" ";
              astack.push(i);  //入栈 
            }
        }
           number++;//前一
以下是一个C语言拓扑排序排课程序的例子: ```c #include <stdio.h> #include <stdlib.h> #define MAX_VERTEX_NUM 100 // 最大顶点数 typedef struct ArcNode { // 边表结点 int adjvex; // 邻接点域,存储该顶点对应的下标 struct ArcNode *nextarc; // 链域,指向下一个邻接点 } ArcNode; typedef struct VNode { // 顶点表结点 int data; // 顶点信息 ArcNode *firstarc; // 边表头指针 } VNode, AdjList[MAX_VERTEX_NUM]; typedef struct { // 图 AdjList vertices; // 邻接表 int vexnum, arcnum; // 顶点数和弧数 } ALGraph; int *etv, *ltv; // 事件最早发生时间和最迟发生时间 int *stack; // 存储拓扑序列的栈 int top = -1; // 栈顶指针 int *indegree; // 存储各个顶点的入度 void CreateGraph(ALGraph *G) { // 创建AOV网 int i, j, k; ArcNode *p; printf("请输入顶点数和弧数:"); scanf("%d,%d", &G->vexnum, &G->arcnum); for (i = 0; i < G->vexnum; i++) { // 初始化邻接表 G->vertices[i].data = i; G->vertices[i].firstarc = NULL; } for (k = 0; k < G->arcnum; k++) { // 建立邻接表 printf("请输入弧头和弧尾:"); scanf("%d,%d", &i, &j); p = (ArcNode *)malloc(sizeof(ArcNode)); p->adjvex = j; p->nextarc = G->vertices[i].firstarc; G->vertices[i].firstarc = p; } } void TopologicalSort(ALGraph *G) { // 拓扑排序 int i, k, gettop; ArcNode *p; int count = 0; // 计数,记录当前已经输出的顶点数 top = -1; // 初始化栈 etv = (int *)malloc(G->vexnum * sizeof(int)); // 事件最早发生时间 for (i = 0; i < G->vexnum; i++) { etv[i] = 0; // 初始化为0 } stack = (int *)malloc(G->vexnum * sizeof(int)); // 存储拓扑序列的栈 indegree = (int *)malloc(G->vexnum * sizeof(int)); // 存储各个顶点的入度 for (i = 0; i < G->vexnum; i++) { // 初始化各个顶点的入度 indegree[i] = 0; } for (i = 0; i < G->vexnum; i++) { // 计算各个顶点的入度 for (p = G->vertices[i].firstarc; p; p = p->nextarc) { indegree[p->adjvex]++; } } for (i = 0; i < G->vexnum; i++) { // 将入度为0的顶点入栈 if (indegree[i] == 0) { stack[++top] = i; } } while (top > -1) { // 栈不为空 gettop = stack[top--]; // 出栈 printf("%d -> ", gettop); // 输出拓扑序列 count++; // 计数 for (p = G->vertices[gettop].firstarc; p; p = p->nextarc) { // 对gettop的每个邻接点的入度减1 k = p->adjvex; if (--indegree[k] == 0) { // 若入度减为0,则入栈 stack[++top] = k; } if (etv[gettop] + 1 > etv[k]) { // 更新各个事件最早发生时间 etv[k] = etv[gettop] + 1; } } } if (count < G->vexnum) { // 拓扑序列中顶点数小于G->vexnum,说明存在环 printf("Error: Graph has a cycle\n"); exit(0); } } int main() { ALGraph G; CreateGraph(&G); TopologicalSort(&G); return 0; } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值