- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
字符串ADT定义与实现
计算机实验:字符串ADT定义与实现
目的
掌握字符串的定义及基本操作的实现。
用堆存储方式保存字符串,实现字符串的各种基本操作,包括赋值、替换、取子串、串连接等。
1.???????用C语言定义字符串的ADT和基本操作。
2.???????实现赋值、替换、取子串、串连接等操作。
3.???????测试自己完成的练习,观察每个操作的执行效果。
PC计算机、Windows操作系统、C/C++开发环境
能够理解并掌握字符串的定义和堆存储方式的实现方法。
1.???????估算各个操作的复杂度和空间利用效率。
#includememory
?
#define?OK 1
#define?ERROR 0
#define?OVERFLOW -1
#define?NOTFOUND -2
#define?MAXLEN 10000????//每次读入的字符串的最大长度
#define?MAXCMD 20???????//每个命令的最大长度
#define?MAXN 10?????????//字符串的最大个数
?
?
typedef?struct
{
????char?*ch;???????//若是非空串,则按串长分配储存区,否则ch为NULL
????int?length;?????//串长度
}String;
?
?
int?StrAssign(String T,char?*chars)
{
????if?(T.ch) free(T.ch);
???
????int?i,len;
????for?(len=0;chars[len];len++);???//计算chars的长度存入len
?
????if?(!len)??
????{
?????牋燭.ch=NULL;ha
牋牋牋牋T.length=0;;har
牋牋}牋T
牋牋elsele
牋牋{ls
牋牋牋牋if?!(T.ch=(char*)malloc(len*sizeof(char))))爎eturn燨VERFLOW;3.?????
牋牋牋牋for?i=0;ilen;i++) T.ch[i]=chars[i];har))
牋牋牋牋T.length=len;;i++
牋牋}牋T
牋?}
牋牋return燨K;h=l
}
?
?
int?StrLength(String T)
{
牋牋return燭.length;T)+
}
?
?
int?StrCompare(String T,String S)
{
牋牋int爄;are
牋牋for?i=0;iS.length iT.length;i++);ha
牋牋牋牋if?T.ch[i]!=S.ch[i])爎eturn燭.ch[i]S.ch[i]?1:-1;rn燨VERF
牋牋return燭.length-S.length;tur
}
?
?
int?StrClear(String T)
{
牋牋if?T.ch) {free(T.ch); T.ch=NULL;}i]
牋牋T.length=0;re
牋牋return燨K;0;r
}
?
?
int?StrConcat(String T,String S1,String S2)
{
牋牋if?T.ch) free(T.ch);rin
?
牋牋if?!(T.ch=(char*)malloc(sizeof(char)*(S1.length+S2.length))))爎eturn燨VERFLOW;练习,观察
牋?i
牋牋int爄;T.c
牋牋for?i=0;iS1.length;i++)牋?/eof(c将串S1先放在T.ch的前面部分
????????T.ch[i]=S1.ch[i];
????for?(i=0;iS2.length;i++)???//将串S2接在后面
????????T.ch[i+S1.length]=S2.ch[i];
????T.length=S1.length+S2.length;
???
????return?OK;
}
?
?
int?StrSub(String T,String S,int?pos,int?len)
{
????if?(pos0 || pos=S.length || len0 || pos+len-1S.length-1)?return?ERROR;??//输入数据不合法
???
????if?(T.ch) free(T.ch);
???
????if?(!len)
????{
????????T.ch=NULL;
????????T.length=0;
????}
????else
????{
????????if?(!(T.ch=(char*)malloc(len*sizeof(char))))?return?OVERFLOW;
????????int?i;
您可能关注的文档
- 多目标的Internet路由优化控制算法.pdf
- 多目标低碳闭环供应链网络优化模型及算法_戴卓_胡凯.pdf
- 多目标规划的一种有效解法.pdf
- 多目标进化算法中选择策略的研究_谢承旺.pdf
- 多种因素对阻垢剂性能的影响(英文).pdf
- 多矩阵变量线性矩阵方程的广义自反解的迭代算法.pdf
- 多策略的机器翻译.pdf
- 多程放大系统光学元件静态波前畸变研究.pdf
- 多种钥匙齿形自动识别系统的设计与实现.pdf
- 多糖结构分析.doc
- 《GB/T 32151.42-2024温室气体排放核算与报告要求 第42部分:铜冶炼企业》.pdf
- GB/T 32151.42-2024温室气体排放核算与报告要求 第42部分:铜冶炼企业.pdf
- GB/T 38048.6-2024表面清洁器具 第6部分:家用和类似用途湿式硬地面清洁器具 性能测试方法.pdf
- 中国国家标准 GB/T 38048.6-2024表面清洁器具 第6部分:家用和类似用途湿式硬地面清洁器具 性能测试方法.pdf
- 《GB/T 38048.6-2024表面清洁器具 第6部分:家用和类似用途湿式硬地面清洁器具 性能测试方法》.pdf
- 《GB/T 18238.2-2024网络安全技术 杂凑函数 第2部分:采用分组密码的杂凑函数》.pdf
- GB/T 18238.2-2024网络安全技术 杂凑函数 第2部分:采用分组密码的杂凑函数.pdf
- 《GB/T 17215.686-2024电测量数据交换 DLMS/COSEM组件 第86部分:社区网络高速PLCISO/IEC 12139-1配置》.pdf
- GB/T 13542.4-2024电气绝缘用薄膜 第4部分:聚酯薄膜.pdf
- 《GB/T 13542.4-2024电气绝缘用薄膜 第4部分:聚酯薄膜》.pdf
文档评论(0)