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