字符串模式匹配实验报告..docVIP

  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文档。上传文档
查看更多
字符串模式匹配实验报告.

2014-2015学年 第一学期实验报告 课程名称: 算法与数据结构 实验名称: 字符串的模式匹配 一、 实验目的 本次实验的目的是熟悉串类型的实现方法和文本模式匹配方法,熟悉串的键盘输入获取方式。 二、 实验内容 简单模式匹配算法和 KMP 算法。 三、 实验环境 VS2010 、win8.1 四、 实验结果 4.1 简单匹配: 输入 五、 附录 城市链表: 5.1 问题分析 该实验要求对链表实现创建,遍历,插入,删除,查询等操作,故使用单链表。 5.2 设计方案 该程序大致分为以下几个模块: 1.创建城市链表模块,即在空链表中插入新元素。故创建城市链表中包涵插入模块。 2.返回位置坐标模块。 3.计算距离模块 4.插入模块。 5.更新城市信息模块 6.删除信息模块。 5.3 算法 5.3.1 根据中心城市坐标,返回在距离内的所有城市: void FindCityDistance(citylist *L){ //根据距离输出城市 L=L-next; while(L != NULL){ if(((L-x-x1)*(L-x-x1)+(L-y-y1)*(L-y-y1)=dis*dis)(((L-x-x1)+(L-y-y1))!=0 )){ printf(城市名称%s\n,L-Name); printf(城市坐标%.2lf,%.2lf\n,L-x,L-y); } L=L-next; } } 该算法主要用到了勾股定理,考虑到不需要实际数值,只需要大小比较,所以只用 横坐标差的平方+纵坐标差的平方 = 距离的平方 判定。 因中心城市本身也在判定范围之内,所以添加了判定条件横纵坐标差的和不能为零。 5.3.2 主程序中循环条件判定: for( ; ; ){ printf(请选择您的操作\n); printf(1.创建城市链表\n); printf(2.根据名字查询城市\n); printf(3.插入\n); printf(4.删除\n); printf(5.更新城市信息\n); printf(6.根据离中心坐标距离查看城市\n); printf(7.退出系统\n); scanf(%d,choice); switch(choice){ ……//case语句 case 7:break; } if(choice == 7) break; } 若用户选择了退出系统选项,则首先跳出switch 在跳出for循环结束程序。 5.4流程图 5.5程序源代码 typedef struct citylist { char Name[20]; double x,y; citylist *next; }citylist, *L; void InitList_SqCity(citylist *L){ //初始化节点 L-next = NULL; } void Insert_sqCity(citylist *L){ //在链表中插入元素 citylist* newNode; newNode=(citylist*)malloc(sizeof(citylist)); if(!newNode) printf(存储分配失败); printf(请输入城市名\n); scanf(%s,newNode-Name); printf(请输城市坐标x y\n); scanf(%lf%lf,(newNode-x),(newNode-y)); while(L-next != NULL){ L = L-next; } newNode-next =L-next; L-next = newNode; } void Create_sqCity(citylist *L){ //创建链表 char ch[100]; int i; printf(输入END退出,输入其余值继续\n); //当输入END时,在任意输入,则退出此操作 scanf(%s,ch); for(;strcmp(ch,END)!=0 ; ){ Insert_sqCity(L); printf(输入END退出,输入其余值继续\n); scanf(%s,ch); } } void Get_sqCityCoord(citylist *L){ //输入城市信息返回坐标 char ch[10]; pri

文档评论(0)

stzs + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档