本科生导师制问题:数据结构和程序设计实验归档材料.docVIP

本科生导师制问题:数据结构和程序设计实验归档材料.doc

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
本科生导师制问题:数据结构和程序设计实验归档材料

计算机科学与技术学院实验课程归档材料规范 实验报告一 实验课名称:数据结构与程序设计实验 实验名称:本科生导师制问题 实验类型:设计型实验 班级: 学号: 姓名: 时间: 问题描述 在高校的教学改革中,有很多学校实行了本科生导师制。一个班级的学生被分给几个老师,每个老师带n个学生,如果该老师还带研究生,那么研究生也可直接带本科生。本科生导师制问题中的数据元素具有如下形式: 导师带研究生 (老师,((研究生1,(本科生1,…,本科生m1)),(研究生2,(本科生1,…,本科生m2))…)) 导师不带研究生 (老师,(本科生1,…,本科生m)) 导师的自然情况只包括姓名、职称;研究生的自然情况只包括姓名、班级;本科生的自然情况只包括姓名、班级。 数据结构设计 本实验使用的数据结构是广义表,广义表采用头尾链表存储结构来实现。 定义教师、学生结点结构体如下: typedef struct GLNode { char name[100]; /*教师或学生的姓名*/ char prof[100]; /*教师结点表示职称,学生结点表示班级*/ int type; /*结点类型:0-教师,1-研究生,2-本科生*/ struct {struct GLNode *hp, *tp;} ptr; /*hp指向同级的下一结点,tp指向下级的首结点*/ }GList; 人员信息的表示形式为:高老师-教授-0、李刚-二班-1、李明-二班-2. 人员信息中的姓名、职称、班级、人员类型用“-”隔开,如高老师-教授-0,“高老师”表示姓名,“教师”表示职称,“0”表示人员的类型是教师;李刚-二班-1,“李刚”表示姓名,“二班”表示班级,“1”表示人员的类型是研究生;李明-二班-2,“李明”表示姓名,“二班”表示班级,“2”表示人员的类型是本科生。 广义表((高老师-教授-0,(李明-一班-2,王平-二班-2)),(李老师-副教授-0,(白梅-二班-1,(李刚-一班-2)))可以用图3表示。 图3 导师制用广义表实现示例 三、算法设计 建立:建立导师广义表。 GList InitGList(){ GList L = NULL, *l; GList e; e = InitGLNode(teacherli, fujiaoshou, 0); InsertFirst_GL(L, e); e = InitGLNode(teachergao, jiaoshou, 0); InsertFirst_GL(L, e); l = ((L-ptr).tp); e = InitGLNode(wangping, erban, 2); InsertFirst_GL(l, e); e = InitGLNode(liming, yiban, 2); InsertFirst_GL(l, e); l = ((((L-ptr).hp)-ptr).tp); e = InitGLNode(baimei, erban, 1); InsertFirst_GL(l, e); l = (((*l)-ptr).tp); e = InitGLNode(ligang, yiban, 2); InsertFirst_GL(l, e); return L; } 插入:将某位本科生或研究生插入到广义表的相应位置。 int InsertFirst_GL(GList *L, GLNode *e){ (e-ptr).hp = *L; *L = e; return 1; } 删除:将某本科生或研究生从广义表中删除。 GList DeleteGLNode(GList *L, char *name){ GList *l = L, *p, temp; if(l){ if(!strcmp((*l)-name, name)){ temp = *l; *l = ((*l)-ptr).hp; return temp; } if(((*l)-ptr).tp){ p = (((*l)-ptr).tp); temp = DeleteGLNode(p, name); if(temp) return temp; } if(((*l)-ptr).hp){ p = (((*l)-ptr).hp); temp = DeleteGLNode(p, name); if(temp) return temp; } }else{

文档评论(0)

专注于电脑软件的下载与安装,各种疑难问题的解决,office办公软件的咨询,文档格式转换,音视频下载等等,欢迎各位咨询!

1亿VIP精品文档

相关文档