版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、数据结构课程设计报告一、 问题描述与分析1、 课程设计目的:数据结构主要介绍一些最常用的数据结构,阐明各种数据结构内在的逻辑关系,讨论其在计算机中的存储表示,以及在其上进行各种运算时的实现算法、并对算法的效率进行简单的分析和讨论。数据结构时介于数学、计算机软件和计算机硬件之间的一门计算机专业的核心课程,它是计算机程序设计、数据库、操作系统、编译原理及人工智能等重要基础,广泛的应用于信息学、系统工程学等各种领域。 数据结构课程设计是为数据结构课程独立开发的实践性教学环节。数据结构课程设计对于巩固数据结构知识,加强学生的实际动手能力和提高学生综合素质是十分必要的。 课程设计的目的:1 要求学生达到
2、熟练掌握c语言的基本知识和技能。2 了解并掌握数据结构与算法的实际方法,具备初步的独立分析和设计能力。3 提高程序设计和调试能力。学生通过上机实习,验证自己实际的算法的正确性。学会有效利用基本调试方法,迅速找出程序代码中的错误并且修改。4 培养算法分析能力。分析所设计算法的时间复杂度和空间复杂度,进一步提高程序设计水平。5 初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能。二、课程设计内容课题一:一元多项式计算1、问题描述1)、能够按照指数降序排列建立并输出多项式;2)、能够完成两个多项式的相加、相减,并将结果输入。2、要求在上交资料中请写明:存储结构、多项式相加的基本
3、过程的算法(可以使用程序流程图) 、源程序、测试数据和结果、算法的时间复杂度、另外可以提出算法的改进方法。3、运行环境: microsoft visual c+ 6.0。visual c+(简称vc)是microsoft公司推出的目前使用极为广泛的基于windows平台的c+可视化开发环境。visual c+ 6.0提供的控制台应用程序对学习和掌握标准c+内容非常有利。“可视”的资源编辑器与mfc类以及应用程序向导,为快速高效地开发出功能强大的windows应用程序提供了极大的方便。利用visual c+ 6.0进行internet、数据库及多媒体等多方面的程序开发也很容易。4、源程序:#in
4、clude iostreamusing namespace std;#define maxsize 10typedef structint xi;int zhi;datatype;typedef struct nodedatatype datamaxsize;int length;dx,*pdx;pdx init_list()dx *s;s=(dx *)malloc(sizeof(dx);if(s)s-length=0;return s;int empty(dx *s)if(s-length=0)return 1;else return 0;int in_list(dx *s,datatype
5、 a)/建立多项式存储结构if(s&s-lengthlength+;s-datas-length-1=a;return 1;else return 0;int insert_list(dx *s,int j,datatype e)/插入if(s&s-lengthlength+;for(int i=s-length-1;ij;i-)s-datai=s-datai-1; s-dataj=e;return 1;else return 0;int delete_list(dx *s,int m)/m就是数组下标if(!s)cout多项式不存在!endl;return -1;if(ms-length)c
6、out删除位置不合法!endl;return 0;for(int j=m;jlength;j+)s-dataj-1=s-dataj;s-length-;return 1;pdx luru(int n)/录入多项式,并存储起来,n为多项式的项数!dx *s;s=init_list();datatype e;cout按从高指数到低指数,输入一元多项式的系数和指数;endl;for(int i=0;in;i+)coute.zhi;if(s-length-1=0&e.zhi=s-datas-length-1.zhi)|e.zhi0)i-;cout输入指数大于前一项错误请重输或小于0!endl;cont
7、inue;coute.xi;in_list(s,e);return s;void print(dx *s)for(int i=0;ilength;i+)if(i0&s-datai.xi=0)cout+;coutdatai.xixdatai.zhi;coutendl;pdx add(dx *s1,dx *s2)dx *s3;s3=init_list();for(int x=0;xlength;x+)s3-length+;s3-datas3-length-1=s1-datax;for(int i=0;ilength;i+) for(int j=0;jlength;j+) if(s2-datai.z
8、hi=s3-dataj.zhi)s3-dataj.xi+=s2-datai.xi;break;else if(s2-datai.zhis3-dataj.zhi)insert_list(s3,j,s2-datai);break;if(s2-datai.zhidatas3-length-1.zhi)in_list(s3,s2-datai);return s3;pdx sub(dx *s1,dx *s2)/s1-s2dx *s3;s3=init_list();datatype e;for(int x=0;xlength;x+)s3-length+;s3-datas3-length-1=s1-data
9、x;for(int i=0;ilength;i+) for(int j=0;jlength;j+) if(s2-datai.zhi=s3-dataj.zhi)s3-dataj.xi-=s2-datai.xi;if(s3-dataj.xi=0)delete_list(s3,j+1);break;else if(s2-datai.zhis3-dataj.zhi)e=s2-datai;e.xi=-1*e.xi;insert_list(s3,j,e);break;if(s2-datai.zhidatas3-length-1.zhi)e=s2-datai;e.xi=-1*e.xi;in_list(s3,
10、e);return s3;pdx bin(dx *s1,dx *s2)dx *s3;s3=init_list();datatype e,a;a.xi=0;a.zhi=0;in_list(s3,a);for(int i=0;ilength;i+)for(int j=0;jlength;j+)e.xi=s1-datai.xi*s2-dataj.xi;e.zhi=s1-datai.zhi*s2-dataj.zhi;for(int k=0;klength;k+)if(e.zhi=s3-datak.zhi)s3-datak.xi+=s2-dataj.xi;break;else if(e.zhis3-da
11、tak.zhi)insert_list(s3,k,e);break;if(s3-length-2=0&e.zhidatas3-length-2.zhi)insert_list(s3,s3-length-1,e);return s3; int main(int argc,int _tchar,int argv)dx *s1,*s2,*s3,*s4,*s5;int i,j;couti;s1=luru(i);coutj;s2=luru(j);s3=add(s1,s2);s4=sub(s1,s2);s5=bin(s1,s2);cout第一个多项式:endl;print(s1);cout第二个多项式:e
12、ndl;print(s2);cout两多项式的和:endl;print(s3);cout两多项式的差endl;print(s4);return 0;5、调试结果:(1) 首先运行文件一元多项式kl.exe (2)输入信息即输入两一元个多项式:y1=x3+2x2+3x+1 y2=4x3+5x2+6x+8(3)输出结果:课程二:运动会分数统计1、问题描述参加运动会有n个学校,学校编号为1n。比赛分成m个男子项目,和w个女子项目。项目编号为男子1m,女子m+1m+w。不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自
13、己设定。(m=20,nm+w|s=0)printf(此次运动会不包括这个项目.nnn); 想在每次查询结束想返回主菜单进行其它项时,应在main( )函数中调用其它函数时再调用main( )函数,如: switch(choice) case 1: inputinformation();writedata();readdata();main(); case 2: output();main(); case 3: inquiry();main(); case 4: readdata();main(); 程序出现语法错误,发现是输入名次信息的地方忘带地址符&,或是程序不完整,只写了一个大括号。如:
14、printf(*名次:); scanf(%d,&hi.cj.ranges);6.2调试分析:(1).函数调用。函数调用是语言中一块十分重要部分,它可以把一个程序分成若干部分,然后进行配置,所以这块内容对我们很重要。(2).对结构体的不熟练。刚开始对结构体不太了解,使调试程序时费了我不少的时间。结构体的嵌套使我很费力气,通过长时间的运用,终于可以得心应手。结构体在我的实习中站了很大的比重,我也很重视它。通过与线性表,循环等的有机搭配,我完成了实习任务。(3).循环的问题。这是我很苦恼,大量的循环语句的应用,分析。使我很头疼,循环是计算机语言中很重要的部分,什么程序也离不开循环,这个问题的解决使我
15、有了坚实的基础。对多层循环的应用也有了深刻的理解。6.3调试结果:(1)首先运行文件运动会统计分数7.exe(2) 输入信息:程序首先赋初值,定义学校的个数为2,男生项目为1,女生项目为1。输入1得到进入输入信息模块。按回车键可得到学校的得分信息和按编号获得的所以信息。(3)输出信息:输入2进入输出信息模块,该模块分四项: 按学校编号输出: 按学校总分输出: 按男团总分输出: 按女团总分输出: 输入2返回输出信息模块,输入0返回主菜单。(4)查询信息:输入3进入信息查询模块: 按学校编号查询 按项目编号查询 输入错误信息时给出提示: 输入2继续查询,输入0返回主菜单(5) 调用信息输入4时显示
16、出所有的信息:7源程序:#include#include#include #include #define n 2/学校数目 #define m 1/男子项目数目 #define w 1/女子项目数目#define null 0typedef struct int itemnum; /项目编号 int top; /取名次的数目 int range5; /名次 int mark5; /分数itemnode; /定义项目结点的类型typedef structint schoolnum; /学校编号 int score; /学校总分 int mscore; /男团体总分 int wscore; /女
17、团体总分 itemnode cm+w; /项目数组headnode;/定义头结点类型headnode hn;/定义一个头结点数组void inputinformation() /输入信息,建立系统int i,j,k,s; for(i=0;in;i+) hi.score=0; hi.mscore=0; hi.wscore=0; /初始化头结点 for(i=0;in;i+) printf(*学校编号:); scanf(%d,&hi.schoolnum); /输入头结点信息 for(j=0;jm+w;j+) printf(*项目编号:); scanf(%d,&hi.cj.itemnum); prin
18、tf(*取前3名or前5名:); scanf(%d,&hi.cj.top); printf(*获得几个名次:); scanf(%d,&k); /输入项目信息 for(s=0;s5;s+) hi.cj.ranges=0, hi.cj.marks=0; /初始化排名和分数 for(s=0;sk;s+) printf(*名次:); scanf(%d,&hi.cj.ranges); /输入所获名次信息 if(hi.cj.top=3) switch(hi.cj.ranges) case 0: hi.cj.marks=0; break; case 1: hi.cj.marks=5; break; case
19、 2: hi.cj.marks=3; break; case 3: hi.cj.marks=2; break; else switch(hi.cj.ranges) case 0: hi.cj.marks=0; break; case 1: hi.cj.marks=7; break; case 2: hi.cj.marks=5; break; case 3: hi.cj.marks=3; break; case 4: hi.cj.marks=2; break; case 5: hi.cj.marks=1; break; hi.score=hi.score+hi.cj.marks;/按取前三名还是
20、取前五名分别记分 if(j=m-1)hi.mscore=hi.mscore+hi.cj.marks;/是男子项目则记到男子分数里面去 else hi.wscore=hi.wscore+hi.cj.marks;/是女子项目则记到女子项目里面去 printf(n); void output() /输出函数 int choice,i,j,k;int remembern;int sign; do printf(*1.按学校编号输出.*n); printf(*2.按学校总分输出.*n); printf(*3.按男团总分输出.*n); printf(*4.按女团总分输出.*n); printf(nn* 请
21、选择编号*nn:); scanf(%d,&choice); switch(choice) case 1:for(i=0;in;i+) printf(nn*学校编号:%dn,hi.schoolnum); printf(*学校总分:%dn ,hi.score); printf(*男团总分:%dn,hi.mscore); printf(*女团总分: %dnnn,hi.wscore); /按编号顺序输出 break; case 2: for(i=0;in;i+)rememberi=i; for(i=0;in;i+) for(j=i+1;jn;j+)if(hrememberi.scorehj.score
22、) k=rememberi;rememberi=rememberj,rememberj=k; / 用冒泡排序方法,用辅助数组记住头结点下标 for(i=0;in;i+) printf(nn*学校编号:%dn,hrememberi.schoolnum); printf(*学校总分:%dn ,hrememberi.score); printf(*男团总分:%dn,hrememberi.mscore); printf(*女团总分: %dnnn,hrememberi.wscore);/按所记下标顺序输出 /按学校总分输出 break; case 3: for(i=0;in;i+) rememberi=
23、i; for(i=0;in;i+) for(j=i+1;jn;j+)if(hrememberi.mscorehj.mscore)k=rememberi;rememberi=rememberj;rememberj=k; for(i=0;in;i+) printf(nn*学校编号:%dn,hrememberi.schoolnum); printf(*学校总分:%dn ,hrememberi.score); printf(*男团总分:%dn,hrememberi.mscore); printf(*女团总分: %dnnn,hrememberi.wscore); /按男团总分输出 break; case
24、 4: for(i=0;in;i+) rememberi=i; for(i=0;in;i+) for(j=i+1;jn;j+) if(hrememberi.wscorehj.wscore) k=rememberi;rememberi=rememberj;rememberj=k; for(i=0;in)printf(错误:这个学校没有参加此次运动会!nnn); elseprintf(要查询的项目编号:); scanf(%d,&j); if(jm+w|j=0) printf(此次运动会没有这个项目nnn);/学校编号超出范围,则输出警告 else printf(这个项目取前 %d名,该学校的成绩如
25、下:n, h0.cj-1.top); for(k=0;km+w|s=0)printf(此次运动会不包括这个项目.nnn);/项目编号超出范围则输出警告elseprintf(该项目取前 %d名,取得名次的学校n,h0.cs-1.top);for(i=0; in;i+) for(j=0;j5;j+) if(hi.cs-1.rangej!=0) printf(学校编号:%d,名次:%dn,hi.schoolnum,hi.cs-1.rangej); /输出该项目取得名次学校的成绩 printf(nnn继续 2,跳出 0n);scanf(%d,&i);printf(nnn);while(i=2); br
26、eak;void writedata() /把数据存储在文件中 file *report; int i; if(report=fopen(sportsdata.txt,w)=null) printf(不能打开文件n); exit(1); for(i=0;in;i+)fwrite(&hi,sizeof(headnode),1,report); fclose(report); /按头结点块写入 void readdata() /读出文件中数据的函数 file *report; int i,j,k,s; if(report=fopen(sportsdata.txt,r)=null) printf(f
27、ile can not be openedn); exit(1); for(i=0;in;i+) printf(*学校编号:); fread(&k,sizeof(int),1,report); printf(%dn,k); printf(*学校总分:); fread(&k,sizeof(int),1,report); printf(%dn,k); printf(*男团总分:); fread(&k,sizeof(int),1,report); printf(%dn,k); printf(*女团总分:); fread(&k,sizeof(int),1,report); printf(%dn,k);
28、 printf(nnn); getch(); for(j=0;jm+w;j+) printf(*项目编号:); fread(&k,sizeof(int),1,report); printf(%dn,k); printf(*所取名次数量:); fread(&k,sizeof(int),1,report); printf(%dn,k); for(s=0;s5;s+) fread(&k,sizeof(int),1,report); if(k!=0) printf(*名次:), printf(%dn,k); for(s=0;s5;s+) fread(&k,sizeof(int),1,report);
29、if(k!=0) printf(*分数:), printf(%dn,k); printf(nnn); getch(); fclose(report); /关闭文件 /按照读一个数据就输出一个数据的方式显示数据内容void main() int choice;printf(=欢迎使用=n); printf(nn*运动会分数统计系统*n); printf(nn*1.输入信息*n);printf(*2.输出信息*n);printf(*3.查询信息*n); printf(*4.调用信息*n); printf(*5.退出系统*nnn);printf(=nn);printf(*请选择要实现步骤的编号:nn
30、);scanf(%d,&choice);switch(choice) case 1: inputinformation();writedata();readdata();main(); case 2: output();main(); case 3: inquiry();main(); case 4: readdata();main(); case 5: exit(0); default: exit(0); 8总结(1).调试中所遇到的较重要问题的回顾:1) 提出问题:所有输入输出内容只能在一屏内显示,学过c语言,很知道”n”是换行,”f”是换屏的,可是在这里就是无法实现。解决问题: 输入clrscr();2)提出问题:设置选项,供用户输入选择时,当按任意键时都会跳入下一步操作,或者直接退出系统。分析问题:在供用户选择时,提供了几个选
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
 - 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
 - 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
 - 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
 - 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
 - 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
 - 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
 
最新文档
- (2025年)安全生产法试题及参考答案
 - 内分泌科糖尿病患者治疗措施
 - 感染科HIV感染预防措施指南
 - 酒店服务质量典型案例分析报告
 - 老年人出科讲座
 - 高校在线教学作业布置与评估方案
 - 小学生气象防灾减灾科普
 - 小学课程资源开发与利用方案
 - 机关单位节能减排考核标准与方法
 - 内科急性胰腺炎患者饮食指导
 - 架桥机安拆安全监理细则
 - 智慧排水系统建设项目方案
 - 峰飞V2000CG型无人驾驶航空器系统项目专用条件
 - 中级注安工程师《安全生产技术基础》考试真题卷(2025年)
 - 钢材中转仓库管理制度
 - 我理想的班级课件
 - 高考文言文18个虚词120实词
 - 放射工作人员健康要求及监护规范
 - 科室6S管理成果汇报
 - 线下陪玩合同范本
 - 受托协议范本
 
            
评论
0/150
提交评论