- 1、本文档共11页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构栈和队列的基本操作
武汉工商学院
《数据结构》课程实验实训报告
实验名称
串
实验序号
学 号
姓 名
班 级
实验日期
2014-12-13
指导教师
成 绩
一、实验目的和要求
目的:掌握栈和队列数据结构的描述,学会针对栈和队列的基本操作。
要求:实验前了解C语言结构化程序设计思想,结构体及指针的应用。
二、实验具体内容及步骤
完成课本p76-P78串的定长顺序存储代码输入和调试。
利用以上串的定长顺序存储代码,实现串的模式匹配算法(p83)。
利用以上代码,编写算法,从串s中删除所有和串t相同的子串,串采用定长顺序存储。
完成课本p79-P81串的堆分配存储代码输入和调试。
利用题4代码,编写算法,实现串的基本操作Replace(S,T,V),串采用堆分配存储。
三、实验结果与分析(程序代码按序粘贴在下面,补充的代码用红色加粗显示,并将运行结果截图)
1.
#includestdio.h
#define maxsize 100
typedef struct
{
char str[maxsize];
int len;
}seqstring;
//2.求串的长度
int lenstr(seqstring *s)
{
int i=0;
while(s-str[i]!=\0)
i++;
return i;
}
//1.创建字符串
seqstring *cseatestr(seqstring *s)
{
gets(s-str);
s-len=lenstr(s);
return s;
}
//3.串连接
void concatstr(seqstring *r1,seqstring *r2)
{
int i;
if(r1-len+r2-lenmaxsize)
printf(两个串太长,溢出!);
else
{
for(i=0;ir2-len;i++)
r1-str[r1-len+i]=r2-str[i];
r1-str[r1-len+i]=\0;
r1-len=r1-len+r2-len;
}
}
//4.求子串
void substr(seqstring *r,int i,int j)
{
seqstring *r1;
int k;
if(i+j-1r-len)
{
printf(子串超界);
return;
}
else
{
for(k=0;kj;k++)
r1-str[k]=r-str[i+k-1];
r1-len=j;
r1-str[r1-len]=\0;
}
printf(取出字符为:);
puts(r1-str);
}
//5.串相等的比较
int equalstr (seqstring *r1,seqstring *r2)
{
int i;
for(i=0;ir1-lenir2-len;i++)
if(r1-str[i]!=r2-str[i])
return(r1-str[i]-r2-str[i]);
return(r1-len-r1-len);
}
//6.插入子串
seqstring *insstr(seqstring *s,seqstring *s1,int i)
{
int k;
if(i=s-len||s-len+s1-lenmaxsize)
printf(\n不能插入!\n);
else
{
for(k=s-len-1;k=i;k--)
s-str[s1-len+k]=s-str[k];
for(k=0;ks1-len;k++)
s-str[i+k]=s1-str[k];
s-len=s-len+s1-len;
s-str[s-len]=\0;
}
return s;
}
//7.删除子串
void delstr(seqstring *r,int i,int j)
{
int k;
if(i+j-1r-len)
printf(所要删除的子串超界!);
else
{
for(k=i+j;kr-len;k++,i++)
r-str[i]=r-str[k];
r-len=r-len-j;
r-str[r-len]=\0;
}
}
void main(){}
2.
#includestdio.h
#includestring.h
#define maxsize 100
typedef struct
{
char str[maxsize];
int len;
}seqstring;
int index(seqstring s,seqstring t)
{
int i,j,k,m,n;
m=s.len;
n=t.l
您可能关注的文档
- 数据结构》申报表.doc
- 数据结构_王翠茹_数据结构习题.doc
- 数据结构与OOP课程设计题目.doc
- 数据结构与算法.docx
- 数据结构与算法.doc
- 数据结构与算法11.ppt
- 数据结构与算法1.ppt
- 数据结构与算法.pptx
- 数据结构与算法4.pptx
- 数据结构与算法作业.pptx
- 2024年阿尔山市四年级数学第一单元考试试卷.doc
- 2025年电信职业技能鉴定检测卷【各地真题】附答案详解.docx
- 2025年电信职业技能鉴定检测卷及参考答案详解【实用】.docx
- 2025年电信职业技能鉴定检测卷【必考】附答案详解.docx
- 2025年电信职业技能鉴定检测卷【轻巧夺冠】附答案详解.docx
- 2025年电信职业技能鉴定检测卷及参考答案详解【A卷】.docx
- 高血压的生活管理和治疗.pptx
- 2025年电信职业技能鉴定检测卷及参考答案详解.docx
- 2025年电信职业技能鉴定检测卷附完整答案详解【名校卷】.docx
- 2025年电信职业技能鉴定检测卷附答案详解【名师推荐】.docx
文档评论(0)