- 1、本文档共65页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四章 串 串虽然是一种特殊的线性表,但由于存储结构有所不同,故其基本操作也不同。 1、基本操作子集不同,比如串包含有联接、求子串等操作 2、操作对象不同,线性表的操作通常以数据元素或结点为操作对象,而串的操作主要以串的整体为操作对象。 1)赋值操作 Assign(s,t) s为串名,t为字符串变量。 Create(s,ss) s为串名,ss为字符序列。 2)判等函数 Equal(s,t) 返回布尔值true或false.s,t可为非空串或空串。 3)求串长函数 Length(s) 返回串s字符的个数。 4)联接函数 Concat(s,t) 返回由串s,t相联接而成的新串。联接运算不满足交换律,但满足结合律。 用线性链表的方式存储串值 结点大小问题 用块链结构存储串值 为便于进行串的操作,当以链表存储串值时,给出头、尾指针,加当前串的长度。称如此定义的串存储结构为块链结构。 设尾指针的目的是为了便于进行联接操作。 块链结构的说明 #define CHUNK_SIZE 1000 //用户定义的结点大小 typedef struct { char ch[CHUNK_SIZE]; //块大小 chunk *next; //指针 } chunk; typedef struct { chunk *head,*tail; //头、尾指针 int length; //长度 } LString; LString clst; 特点:每个串的串值各存储在一组地址连续的存储单元中,但它们的存储地址是在程序执行过程中动态分配而得。 typedef struct{ char *ch; int length; }HString; 使用时必须分配(malloc)和回收(free)内存。 1、赋值操作Assign(s,t) Status Assign( HString t; char *s ) { //将s串的值赋给t串 if( s.ch ) free( t.ch ); for( i=0, c=s; c; i++, c++ ); //求s的长度 if( !i ){ t.ch = NULL; t.length = 0;} else{ if(!(t.ch=(char*)malloc(i*sizeof(char)))) return OVERFLOW; t.ch[0..i-1] = s[0..i-1]; t.length = i; } return OK; } 算 法 4.9 2、联接运算Concat Status Concat( HString t, HString s1, HString s2 ) { //连接s1, s2到t中 if( t.ch ) free( t.ch ); //释放原空间 if(!(t.ch=(char*)malloc(s1.length+s2.length)*sizeof(char)))) return OVERFLOW; //分配空间 t.ch[0..s1.length-1] = s1.ch[0..s1.length-1]; //处理s1 t.length = s1.length + s2.length; //长度 t.ch[s1.length..t.length-1] = s2.ch[0..s2.length-1]; //s2 } 3、求子串函数Substr Status SubStr( HString sub, HString s, int pos, int len ) { //从s的pos位置取len长的子串,由sub返回 if(pos1||poss.length||len0||lens.length-pos+1) return ERROR; //非法 if( sub.ch ) free( sub.ch ); //释放原有空间 if( !len ){ sub.ch = NULL; sub.length = 0 } //空串 else{ sub.ch = (char*)malloc(len*sizeof(char));
文档评论(0)