chap串的存储与基本概念.pptVIP

  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文档。上传文档
查看更多
chap串的存储与基本概念

4.1 串的抽象数据类型的定义 串的基本概念 串的抽象数据类型 串的常用操作简介 算法4.1分析 串的操作 1、给串变量赋值(strcpy 或=) 2、串的复制(strcpy,strncpy) 3、串的比较(strcmp) 4、求串的长度(strlen) 5、串连接(strcat) 6、定位函数(strstr) 7、取子串(substring) 8、串插入(strinsert) 9、串删除(strdelete) 10、串替换(strreplace) 练习 1.以下叙述中正确的是 。 ? A.串是一种特殊的线性表 B.串的长度必须大于零 ? C.串中元素只能是字母 D.空串就是空白串 2.空串与空格串是相同的,这种说法____。 ? A. 正确 B. 不正确 3.串是一中特殊的线性表,其特殊性体现在____。 ? A. 可以顺序存储 B. 数据元素是一个字符 ? C. 可以链接存储 D. 数据元素可以是多个字符 4.设有两个串p和q,求q在p中首次出现的位置的运算称作____。 ? A. 连接 B. 模式匹配 ? C. 求子串 D. 求串长 5.设串s1=’ABCDEFG’,s2=’PQRST’,函数con (x,y)返回x和y串的连接串,subs(s,i,j)返回串s的从序号i的字符开始的j个字符组成的子串,len(s)返回串s的长度,则con (subs (s1,2,len (s2)), subs (s1,len (s2),2))的结果串是____。 ? A. BCDEF B. BCDEFG ? C. BCPQRST D. BCDEFEF 6.设串的长度为n,则它的子串个数为 。 ? A.n B.n(n+1) C.n(n+1)/2 D.n(n+1)/2+1 习题 4.2填空 1.串的两种最基本的存储方式是____。 2.两个串相等的充分必要条件是____。 3.空串是____,其长度等于____。 4.空格串是____,其长度等于____。 5.设s=’I︺AM︺A︺TEACHER’,其长度是____。 4.3 判断题 1.串是由有限个字符构成的连续序列,串长度为串中字符的个数,子串是主串中符构成的有限序列。 () 2.子串定位函数的时间复杂度在最坏情况下为O(n*m),因此子串定位函数没有实际使用的价值。 () 3.KMP算法的最大特点是指主串的指针不需要回溯。 () 4.设模式串的长度为m,目标串的长度为n;当n≈m且处理只匹配一次的模式时,朴素的匹配(即子串定位函数)算法所花的时间代价也可能会更为节省。 () 5.如果一个串中的所有字符均在另一串中出现,则说前者是后者的子串。 () 4.1 串的抽象数据类型的定义 串的基本概念 串的抽象数据类型 串的常用操作简介 算法4.1分析 初始化strAssig(T,chars) strAssign(Sstring T,char str[100]) { i=0; while(str[i]!=‘\0’) T[i+1]=str[i++]; T[0]=i; } If(S1[0]MAXSTRSIZE) { If (S1[0]+S2[0] = MAXSTRLEN) 连接过程: 1)照抄s1 2)照抄s2 else 就是前面照抄s1,后面抄写 (MAXsiz-s1[0])的s2的元素) } 二、串的堆分配存储表示 堆分配特点 堆串的常用操作 算法4.1分析 初始化strAssig(T,chars) strAssign(Sstring T,char str[100]) { i=0; while(str[i]!=‘\0’) T[i+1]=str[i++]; T[0]=i; } status strAssign(Hstring T,char *str) 求出str的长度 strlen(str) 依据str的长度盖房子T T.ch=(char*)malloc( strlen(str)*sizeof(char)); 把str的内容抄写到T的各个字符元素中 T.ch[0]=str[0] T.ch[1]=str[1] ……T.ch[T.length-1]=str[T.length-1]; 初始化strAssig(T,chars)动态数组 量体裁衣,求出chars的实际长度 strlen(); 若chars是空的=0 T.length=0 T.ch=NULL 非空的话 为T.ch开辟一个至少strlen(chars)连续的空间 抄写字符 T.le

文档评论(0)

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

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

1亿VIP精品文档

相关文档