




已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
中北大学数 据 结 构课 程 设 计 说 明 书学生姓名:张宁学 号:1021011524学 院:软件学院专 业:软件工程题 目:教学计划编制问题指导教师何志英2011年12月20日1. 设计任务概述1.1问题描述大学的每个专业都要制定教学计划。针对软件工程本专业制定一个教学计划。假设任何专业都有固定的学习年限,每学年含两学期,每学期的时间长度和学分上限值均相等,每个专业开设的课程都是确定的,而且课程在开设时间的安排必须满足先修关系。每门课程有哪些先修课程是确定的,可以有任意多门,也可以没有。每门课恰好占一个学期。试在这样的前提下设计一个教学计划编制程序。1.2需求分析根据问题描述及要求,可知设计中需要定义先修关系的AOV网图中的顶点及弧边的结构体,在运行结果中将图的信息显示出来,利用先修关系将课程排序,最后解决问题输出每学期的课程。(1)用学分来实现每学期课程数大致相同;(2)根据教学计划中的课程及其关系和学分来定义图的顶点及边的结构体。(3)创建图CreateGraph():结合先修关系的AOV网,采用邻接表存储。(4)菜单OUTPUT():显示代号所对应课程及课程的先修课程。(5)拓扑排序TopoSort(G):将课程排序后并决定出每学期所学课程。(6)输出图G的信息Display(G):将图的顶点和弧边输出。1.3本程序包括2个模块:主程序模块和拓扑排序模块。拓扑排序模块主程序模块2. 本设计所采用的数据结构(1)void OUTPUT() /显示代号所对应课程及课程的先修课程(2) int LocateVex(ALGraph G, VertexType u) /查找图中某个顶点位置(3) int CreateGraph(ALGraph G) /采用邻接表存储结构(4) void Display(ALGraph G) /输出图G的信息(5) void FindInDegree(ALGraph G, int indegree) /求顶点的入度(6) void puanduan(VertexType str,struct Name name,int n)(7) int InitStack(SqStack &S) /栈的初始化(8) int StackEmpty(SqStack S) /判空(9) int Pop(SqStack &S, SElemType &e) /出栈(10) int Push(SqStack &S, SElemType e) /入栈(11) int TopoSort(ALGraph G,AdjList Temp,struct Name name) /拓扑排序(12) void main() /主函数3. 功能模块详细设计3.1详细设计思想12 main() 1 3 411 2 5 6 7 8 9103.2 核心代码3.21数据类型定义(1)头结点,表结点,邻接表的定义typedef char VertexTypeMAX_NAME; int TotalTerms ; /学期总数int MaxScores; /学分上限typedef struct ArcNode int adjvex; / 该弧所指向的顶点的位置 弧的节点结构 struct ArcNode *nextarc; /指向下一条弧的指针ArcNode; / 表结点typedef struct VNode VertexType data; /顶点信息 int grades; /存储学分信息 ArcNode *firstarc; /指向第一条依附该顶点的弧的指针VNode, AdjListMAX_VERTEX_NUM; / 头结点typedef struct ALGraph /邻接表 AdjList vertices; /vertices 存储课程名 int vexnum, arcnum; / 图的当前顶点数和弧数ALGraph;邻接表的基本操作:void CreatGraph(ALGraph *);创建邻接表void FindInDegree(ALGraph , int * );求一个结点的入度int TopoSort(ALGraph G,AdjList Temp,struct Name name) /拓扑排序(2)栈的定义:typedef int SElemType; / 栈类型#define Stack_NUM 20 /存储空间初始分配量#define Stack_MoreNUM 5 / 存储空间分配增量typedef struct SqStack SElemType *base; SElemType *top; int stacksize; /分配的存储空间SqStack;基本操作:void InitStack (SqStack *S);栈的初始化int StackEmpty(SqStack S);判断栈是否为空void Push(SqStack *S, int );入栈操作int Pop(SqStack *S, int *e);出栈操作3.22系统主要子程序详细设计(1)主函数模块设计void main() ALGraph G; AdjList Temp; struct Name nameN=C1,C2,C3,C4,C5,C6,C7,C8,C9,C10,C11,C12; OUTPUT(); printf(*教学计划编制问题*n ); printf( 请输入学期总数:); scanf(%d,&TotalTerms); printf(请输入学期的学分上限:); scanf(%d,&MaxScores); CreateGraph(G); Display(G); TopoSort(G,Temp,name); printf(OKn); scanf(*c);(2)拓扑排序模块设计int TopoSort(ALGraph G,AdjList Temp,struct Name name) int i, k, j = 0, count, indegreeMAX_VERTEX_NUM; SqStack S; ArcNode *p; FindInDegree(G, indegree); / 对各顶点求入度 InitStack(S); / 初始化栈 for (i = 0;i nextarc)/ 对i号顶点的每个邻接点的入度减1 k = p-adjvex; if (!(-indegreek) / 若入度减为0,则入栈 Push(S, k); if (count G.vexnum) printf(此有向图有回路无法完成拓扑排序); return ERROR; else printf( 为一个拓扑序列); printf(n); int q=1,Z=0; while (q = TotalTerms) int C = TempZ.grades ; printf(n第%d个学期应学课程:,q); while (C = MaxScores) C = C + TempZ+1.grades; if (Z G.vexnum) puanduan(TempZ.data,name,N); +Z; printf(n); if (q = TotalTerms)printf( n课程编制完成!); q+; return OK;3.3 程序运行结果(1)主界面设计显示课程代号所对应课程及先修课程。(2)输入1-16的任意数回车(3)按要求输入学期数,学分上限,课程数,课程号和各课程的学分:(4)输入各课程先修课程,回车,运行结果:4. 课程设计心得、存在问题及解决方法经过这次这次课程设计,我学到很多。首先是一个总体思想,先确
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年环境工程师专业资格认证模拟题库及答案
- 2025年宿迁市中考物理试题(含答案)
- 2025年可持续发展与生态保护课程考试试卷及答案
- 夏季2025年交通安全工作总结
- 2025年老年人及慢性病健康管理知识培训考题及答案(课前)
- 2025年健康管理师考试相关试题及答案
- 2025年成功就业手册各行业通-用招聘笔试技巧与预测试题
- 北京市门头沟区2023-2024学年七年级上学期期末考试数学考试题目及答案
- 北京市门头沟区2023-2024学年九年级下学期初中学业水平考试(一模)道德与法制考试题目及答案
- 2025年高校科研岗位招聘面试题解析
- 眼科质量与安全工作制度
- 《油井工程课件:钻井技术培训》
- 2024年秋新仁爱科普版七年级上册英语第1~6单元高频率常用常考动词100个
- 气道管理技术
- 电脑和打印机维保服务投标文件、方案
- GB/T 5483-2024天然石膏
- 第四届全国冶金矿山行业职业技能竞赛(磨矿分级工)理论参考试题库(含答案)
- 50MWp渔光互补光伏电站项目箱式变压器安装施工危险源辨识及防范措施
- 2024至2030年中国军工压缩机行业投资前景及策略咨询研究报告
- 反诈知识竞赛题库及答案(共286题)
- 2024年新农村雨污分流建设合同
评论
0/150
提交评论