欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    数据结构课程设计教学计划编制问题报告Word格式文档下载.docx

    • 资源ID:22347699       资源大小:142.96KB        全文页数:11页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    数据结构课程设计教学计划编制问题报告Word格式文档下载.docx

    1、每门课程有哪些先修课程是确定的,可以有任意多门,也可以没有。每门课恰好占一个学期。试在这样的前提下设计一个教学计划编制程序。1.2需求分析根据问题描述及要求,可知设计中需要定义先修关系的AOV网图中的顶点及弧边的结构体,在运行结果中将图的信息显示出来,利用先修关系将课程排序,最后解决问题输出每学期的课程。(1)用学分来实现每学期课程数大致相同;(2)根据教学计划中的课程及其关系和学分来定义图的顶点及边的结构体。(3)创建图CreateGraph():结合先修关系的AOV网,采用邻接表存储。(4)菜单OUTPUT():显示代号所对应课程及课程的先修课程。(5)拓扑排序TopoSort(G):将课

    2、程排序后并决定出每学期所学课程。(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)

    3、 /求顶点的入度(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() /主函

    4、数3. 功能模块详细设计3.1详细设计思想3.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; /存储学分信息

    5、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

    6、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

    7、 );入栈操作int Pop(SqStack *S, int *e);出栈操作3.22系统主要子程序详细设计(1)主函数模块设计void main() ALGraph G; AdjList Temp; struct Name nameN=C1,C2C3C4C5C6C7C8C9C10C11C12; OUTPUT(); printf(*教学计划编制问题*n ); printf( 请输入学期总数:); scanf(%d,&TotalTerms);请输入学期的学分上限:MaxScores); CreateGraph(G); Display(G); TopoSort(G,Temp,name);OKn*c

    8、(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;(-indegreek) / 若入度减为0,则入栈 Push(S, k); if (count G.vex

    9、num) 此有向图有回路无法完成拓扑排序 return ERROR; else printf( 为一个拓扑序列n int q=1,Z=0; while (q = TotalTerms) int C = TempZ.grades ;n第%d个学期应学课程:,q); while (C = MaxScores) C = C + TempZ+1.grades; if (Z puanduan(TempZ.data,name,N); +Z; if (q = TotalTerms)printf( n课程编制完成! q+; return OK;3.3 程序运行结果(1)主界面设计显示课程代号所对应课程及先修课程。(2)输入1-16的任意数回车(3)按要求输入学期数,学分上限,课程数,课程号和各课程的学分:(4)输入各课程先修课程,回车,运行结果:4. 课程设计心得、存在问题及解决方法经过这次这次课程设计,我学到很多。首先是一个总体思想,先确定总体结构。用邻接表把图存储起来,然后用拓扑排序实现先修关系。其中还用到了栈,进栈是要判断栈是否为满,若满则需要再开辟存储空间,如果开辟失败,存储也就失败了。出栈要判断栈是否空,若空,则出栈失败,且返回错误。一开始程序不能运行,后来才找见错误,原来我错加了“&”符号,可见一点疏忽就会导致整个程序无法运行。以后要更加细心的写程序啦!


    注意事项

    本文(数据结构课程设计教学计划编制问题报告Word格式文档下载.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开