ImageVerifierCode 换一换
格式:DOCX , 页数:39 ,大小:934.55KB ,
资源ID:8626927      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8626927.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(课程设计实践报告.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

课程设计实践报告.docx

1、课程设计实践报告北京工商大学课 程 设 计 实 践 报 告学院:计算机与信息工程学院 课程名称: 算法与数据结构 任课教师: 叶 红 班级: 工科092 学号: 姓名: 同组学生:无 实践地点:北京工商大学良乡校区工二楼406 实践时间:2011年1月3日至2011年1月7日1、课程设计题目内容: 对一批汽车牌照进行排序和查找排序和查找是在数据信息处理中使用频度极高的操作。为加快查找的速度需先对数据记录按关键字排序,在汽车数据的信息模型中,汽车牌照是关键字,而且是具有结构特点的一类关键字。因为汽车牌照号是数字和字母混编的,例如 01B7328, 这种记录集合是一个适于利用多关键字进行排序的典型

2、例子,故我们可以利用链式基数排序方法实现排序。在排序基础上,利用二分查找的思想,实现对这批汽车记录按关键字的查找。2、设计要求基本要求: 利用链式基数排序和二分查找的思想完成程序设计任务。3、设计内容(1) 需求分析程序的功能: 主要功能是对含有关键字的批量数据进行排序和查找;另外根据实际增添了输出到文件、删除、插入、简单统计功能。输入输出的要求: 程序会显示提示,根据提示输入数字、字符或数据。测试数据: 测试数据的每个记录包括五项,分别为牌照号码、汽车商标、颜色、注册日期和车主的姓名,其中牌照号码为七位(k0-k6),输入形式如下:K0 和 k1 输入值为01-04(代表地区),k2输入值为

3、 AZ(代表车的使用类型),后4位为 00009999(代表车号),例如: O1B7328。其余四项输入内容因为不涉及本程序的核心思想,故只要求一般字符串类型即可。查询时,输入合法的汽车牌照号码。测试数据要求用30个左右的数据项进行测试,头两位暂限定 0104,第3位为 AZ,以便可使牌照号码相对集中。程序测试数据:3001S5842 将明 2007-12-02 blue jid04D2154 陈琳 2005-11-01 yellow jo 02A0021 潘晓静 2011-04-22 white jae01S8930 李峰 2010-08-13 green aie03C3589 张三 200

4、7-02-18 blue nhi04E2184 Lucy 2009-11-28 black as604A2505 赵晗 2009-10-30 brown ja 03C3269 Lily 2007-11-30 pink jos03B3568 Tom 2005-12-17 blue jos01A8983 Jim 2006-02-19 white kfe02A7777 韩梦龙 2005-02-07 black vds02C2222 钱国正 2009-08-05 green yer01G8652 刘晓莉 2008-11-07 white kfe03H0029 Kasserine 2008-04-08

5、black xfd04G9665 索海丰 2009-04-09 red trs03B3222 唐如云 2007-10-08 brown htr02L6622 王睫 2007-11-08 blue nrr04L1122 Shelly 2006-11-03 black gf04A2200 David 2009-02-22 red ert01E8000 赵远 2007-03-08 pink tre02V0009 唐文 2006-07-02 blue thh01B3321 郑华 2008-12-02 white jh03S6699 索耀光 2008-01-01 white rd03D4115 赵沙 2

6、007-11-11 yellow kew01F6339 赵欢欢 2007-07-14 red kfe02H7775 叶丽娜 2009-08-15 brown wg02A8993 孙珍珍 2010-11-27 white wb02P8692 赵楠 2006-10-12 black trt04W5524 孙中华 2004-03-21 yellow ms03W6688 John 2007-01-11 pink esg(2) 概要设计本程序所用的抽象数据类型的定义:ArrType / 指针数组类型SLList / 静态链表类型SLCell / 静态链表的结点类型KeysType / 定义关键字类型为字

7、符型InfoType / 定义其它数据项的类型主程序的流程及各程序模块之间的层次关系:开始先选择读入原始数据方式:1: 从文件读入(在桌面建立test.txt文档,第一行为记录数,记录数=10000,记录数必须符实,否则程序出错;第二行开始数据,数据用空格隔开,例如: 01S5842 将明 2007-12-02 blue jid);2: 直接用程序内数据。然后对数据进行操作:1: 按车牌号排序并输出; 是否输出到文件?(y/n)2: 查找; 1): 按车牌号查找(排序后进行); 0: 退出 1:删除2): 按车牌号前两位查找;3): 按车牌号第三位查找。3: 按顺序插入数据;(排序后)4: 简

8、单统计。 1): 按车牌号前两位统计; 2): 按车牌号第三位统计。(3) 详细设计采用C语言定义相关的数据类型:typedef struct InfoType / 车主姓名等其它信息 char name17; char date12; char color11; char mark10;InfoType; / 定义其它数据项的类型 typedef char KeysType; / 定义关键字类型为字符型 typedef struct SLCell / 静态链表的结点类型 KeysType keysMAX_NUM_OF_KEY+1; / 关键字(字符串末尾+0) InfoType oth; /

9、 其它数据项 int next;SLCell;typedef struct SLList / 静态链表类型 SLCell rMAX_SPACE; /* 静态链表的可利用空间,r0为头结点*/ int keynum; / 记录的当前关键字个数 int recnum; / 静态链表的当前长度SLList;typedef int ArrTypeRADIX; / 指针数组类型各模块的算法:基数排序:void Distribute(SLCell r,int i,ArrType f,ArrType e);/*静态键表L的r域中记录已按(keys0,keysi-1)有序。本算法按第i个关键字keysi建立R

10、ADIX个子表,使同一子表中记录的keysi相同。f0.RADIX-1和e0.RADIX-1分别指向各子表中第一个和最后一个记录*/void Collect(SLCell r,ArrType f,ArrType e);/*本算法按keysi自小至大地将f0.RADIX-1所指各子表依次链接成一个链表,e0.RADIX-1为各子表的尾指针。*/void Sort(SLList L,int adr);/*求得adr1.L.length,adri为静态链表L的第i个最小记录的序号*/void Rearrange(SLList &L,int adr);/*adr给出静态链表L的有序次序,即L.radr

11、i是第i小的记录。本算法按adr重排L.r,使其有序。*/void RadixSort(SLList &L);/*L是采用静态链表表示的顺序表。对L作基数排序,使得L成为按关键字自小到大的有序静态链表,L.r0为头结点。*/void write(SLList l); / 输出到文件查找:int judge(char s); / 判断车牌号是否合法 int Search1(SLList ST); /* 在表ST中折半查找其关键字等于key的数据元素。若找到,则打印该元素在表中的信息*/void Delete(SLList *l,int d); / 删除l中第d个记录void Search2(SL

12、List l); / 据车牌号前两位搜索 void Search3(SLList l); / 据车牌号第三位搜索插入:int Read(SLList l,SLCell *r); /* 读取车牌号到r,若l中有此车牌号则读取失败*/ void Insert(SLList *l); /* 在l中按基数排序顺序插入车牌号及其他信息*/统计:void Statistic1(SLList l); / 据车牌号前两位进行统计 void Statistic2(SLList l); / 据车牌号第三位进行统计函数的调用关系图: (4) 调试分析调试中遇到的问题及对问题的解决方法:我在调试中遇到了许多问题,由于

13、问题太多无法一一说明,这里只说一些编译无错误而程序无法正常运行,或者程序的执行结果与预想的不同,其它的大部分错误软件在编译时会有提示,就不说了。1、出现如图1情况的,我碰到的有几种。图11) scanf或fscanf语句中一定要用变量的地址,而不是变量本身。这种错误在学习C语言时就强调过,但编程时还是得小心,我的程序在编了300多行时出现这个错误,费了好些时间才查找出来;2) 数组或其它变量定义空间不足。例如在基数排序中,需要两个指针数组,大小与基数相同,如果小于基数的话,会出现图1所示的情况。2、程序执行结果与预想结果不同,如图2和图3所示图2这里有一个经常不经意犯的小错误,就是经常把“=”

14、写成“=”,上图中while(a=0);以下还有一例:图4和图5中,if (c=y)。图3图4图53、有三个问题我不知如何解决:图4和图5中,运行结果是打印完“是否输出到文件?(y/n)”后直接回车打印“输入错误”,之间并没有让输入字符进行选择;图5中程序中使用的是scanf函数而不是getch()函数,因为编译时会提示没有getch()此函数,应该如何做才能把它找出来?如图6、图7和图8所示,当进行选择时,若输入字母,则会进入死循环,而输入其它数字时则不会,我试了一下,当输入如!#等特殊字符时也会进入死循环,我暂时没能解决掉这个问题。图6图7图8暂时就这些问题了。(5) 使用说明及测试结果程

15、序开始后,先选择读入原始数据方式;选择后,程序会先将数据按原来顺序打印出来;然后程序显示主菜单,对数据进行操作;1:按车牌号排序并输出;程序会先对原始数据以车牌号为关键字进行基数排序并输出; 输出后程序会提示是否输出到文件,进行选择;若选择“y”,程序会将排好序的数据记录在桌面建立txt文档保存;若选择“n”,程序会继续回到主菜单。2: 查找; 1): 按车牌号查找(排序后进行); 程序会要求输入要查找的车牌号,读入后对其合法性进行检验,若不合法(格式不正确),会要求重新输入;若合法,则查找。查找到后,程序会打印出车牌号的位置及其相关信息,然后进行选择是否删除;若未查找到,则打印“未找到与此车

16、牌号相关的信息”;2): 按车牌号前两位查找;程序读入前两位后,会依次将满足条件的车牌号及其它相关信息打印出来,并在最后统计有多少个记录满足条件;3): 按车牌号第三位查找; 同前一个查找类似,程序找到满足条件的车牌号后会依次打印出车牌号及其相关信息,并在最后总和共有多少记录满足条件。先说,4: 简单统计。 1): 按车牌号前两位统计; 程序会对已存在的记录以前两位进行统计,分别打印出各个种类有多少个;2): 按车牌号第三位统计程序会对已存在的记录以车牌号第三位进行统计,分别打印出各个种类有多少个。3: 按顺序插入数据;(排序后)程序会先要求输入要插入数据的车牌号,进行判断是否合法,不合法包括

17、格式不正确和原始数据中已存在,程序会给出相应的提示,要求不合法的重新输入,然后要求输入车主姓名及其它相关信息,进行插入操作,成功后程序会提示插入成功并将所在位置打印出来;最后可以选择主菜单中的排序进行查看插入的数据及其所在位置。完成操作后,想退出程序的可以通过主菜单中的“0:退出”实现,其它菜单中一样可以通过此功能退出当前菜单。(6) 源程序(带注释)这是我从cpp文件中直接复制粘贴过来的:#include#include #include #include #include #define N 30#define RADIX 26 /* 关键字基数,此时是二十六个字母(包括十进制整数)的基数

18、*/#define MAX_SPACE 10000 / 链表最大空间 #define MAX_NUM_OF_KEY 7 / 关键字位数 typedef struct InfoType / 车主姓名等其它信息 char name17; char date12; char color11; char mark10;InfoType; / 定义其它数据项的类型 typedef char KeysType; / 定义关键字类型为字符型 typedef struct SLCell / 静态链表的结点类型 KeysType keysMAX_NUM_OF_KEY+1; / 关键字(字符串末尾+0) Info

19、Type oth; / 其它数据项 int next;SLCell;typedef struct SLList / 静态链表类型 SLCell rMAX_SPACE; /* 静态链表的可利用空间,r0为头结点*/ int keynum; / 记录的当前关键字个数 int recnum; / 静态链表的当前长度SLList;typedef int ArrTypeRADIX; / 指针数组类型int menu0(); / 选择读入原始数据方式 int menu(); / 总菜单 int menu1(); / 查找菜单 int menu11(); / 删除菜单 int menu2(); / 统计菜单

20、 int duru(SLList *l,int r); / 执行读入原始数据 void print(SLList L,int w); / 按数组序号输出静态链表void write(SLList l); / 输出到文件void Distribute(SLCell r,int i,ArrType f,ArrType e);/*静态键表L的r域中记录已按(keys0,keysi-1)有序。本算法按第i个关键字keysi建立RADIX个子表,使同一子表中记录的keysi相同。f0.RADIX-1和e0.RADIX-1分别指向各子表中第一个和最后一个记录*/void Collect(SLCell r,

21、ArrType f,ArrType e);/*本算法按keysi自小至大地将f0.RADIX-1所指各子表依次链接成一个链表,e0.RADIX-1为各子表的尾指针。*/void Sort(SLList L,int adr);/*求得adr1.L.length,adri为静态链表L的第i个最小记录的序号*/void Rearrange(SLList &L,int adr);/*adr给出静态链表L的有序次序,即L.radri是第i小的记录。本算法按adr重排L.r,使其有序。*/void RadixSort(SLList &L);/*L是采用静态链表表示的顺序表。对L作基数排序,使得L成为按关键

22、字自小到大的有序静态链表,L.r0为头结点。*/int judge(char s); / 判断车牌号是否合法 int Search1(SLList ST); /* 在表ST中折半查找其关键字等于key的数据元素。若找到,则打印该元素在表中的信息*/void Search2(SLList l); / 据车牌号前两位搜索 void Search3(SLList l); / 据车牌号第三位搜索 void Statistic1(SLList l); / 据车牌号前两位进行统计 void Statistic2(SLList l); / 据车牌号第三位进行统计 void Delete(SLList *l,

23、int d); / 删除l中第d个记录 int Read(SLList l,SLCell *r); /* 读取车牌号到r,若l中有此车牌号则读取失败 */void Insert(SLList *l); /* 在l中按基数排序顺序插入车牌号及其他信息 */int main() SLList l; int a,o,x,y,z; l.recnum=N; l.keynum=MAX_NUM_OF_KEY; do a=menu0(); a=duru(&l,a); while(a=0); printf(车牌号排序前:n); print(l,0); do x=menu(); switch(x) case 1:

24、 RadixSort(l); printf(车牌号排序后:n); print(l,0); write(l); break; case 2: do y=menu1(); switch(y) case 1: o=Search1(l); if (o) Delete(&l,o); break; case 2:Search2(l);break; case 3:Search3(l);break; case 0:break; while(y!=0); break; case 3: if (l.recnumMAX_SPACE) Insert(&l); break; else printf(空间已满,无法插入!

25、n); break; case 4: do z=menu2(); switch(z) case 1:Statistic1(l);break; case 2:Statistic2(l);break; case 0:break; while(z!=0); break; case 0: printf(nttt Bye bye!nnn); break; while(x!=0); system(pause); return 0; int menu0() int x; printf( -n); printf( | 1: 从文件读入(在桌面建立test.txt文档,第一行为记录数, |n); printf(

26、 | 记录数=10000,记录数必须符实,否则程序出错;第二行 |n); printf( | 开始数据,数据用空格隔开,例如: |n); printf( | 01S5842 将明 2007-12-02 blue jid); |n); printf( | 2: 直接用程序内数据。 |n); printf( -n); printf(please select(1-2):); scanf(%d,&x); while(x2) printf(输入错误!n); printf(Please enter the number(1-2):); scanf(%d,&x); ; return x;int menu(

27、) int x; printf( -n); printf( | 0: 退出! |n); printf( | 1: 按车牌号排序并输出; |n); printf( | 2: 查找; |n); printf( | 3: 按顺序插入数据;(排序后) |n); printf( | 4: 简单统计。 |n); printf( -n); printf( please select(0-4):); scanf(%d,&x); /怎样能避免输入两个数字和字母的情况? while(x4) printf(输入错误!n); printf(Please enter the number(0-4):); scanf(%

28、d,&x); ; return x;int menu1() int x; printf( -n); printf( | 0: 退出! |n); printf( | 1: 按车牌号查找(排序后进行);|n); printf( | 2: 按车牌号前两位查找; |n); printf( | 3: 按车牌号第三位查找。 |n); printf( -n); printf( please select(0-3):); scanf(%d,&x); while(x3) printf(输入错误!n); printf(Please enter the number(0-3):); scanf(%d,&x); ; return x;int menu11() int x; printf( -n); printf( | 0: 退出

copyright@ 2008-2022 冰豆网网站版权所有

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