数据结构课件第4章串幻灯片.ppt

  1. 1、本文档共42页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* * * * * * * * * * * * * * * * * * * * * 堆存储结构的优点:堆存储结构既有顺序存储 结构的特点,处理(随机取子串)方便,操作中对 串长又没有任何限制,更显灵活,因此在串处理的 应用程序中常被采用。 定长顺序存储表示和堆分配存储表示通常为高 级程序设计语言所采用。 ▲ 4.2.3 串的块链存储表示 串值也可用单链表存储,简称为链串。 链串与 单链表的差异只是它的结点数据域为单个字符。 S A B C D E ^ S A B C D E ^ 优点:便于插入和删除 缺点:空间利用率低 为了提高空间利用率,可使每个结点存放多个字符 (这是顺序串和链串的综合 (折衷) ),称为块链结构。 S A B C D E # ^ 存储密度 = 数据元素所占存储位 实际分配的存储位 实际应用时,可以根据问题所需来设置结点的大小。 例如:在编辑系统中,整个文本编辑区可以看成是 一个串,每一行是一个子串,构成一个结点。即: 同一行的串用定长结构(80个字符),行和行之间 用指针相联接。 结点结构用 C 语言定义如下: #define CHUNKSIZE 80 // 可由用户定义的块大小 typedef struct Chunk { // 结点结构 char ch[CHUNKSIZE]; struct Chunk *next; } Chunk; 为了便于进行串的操作(联接),当以块链存储 串值时,除头指针外还可附设一个尾指针指示链表中 的最后一个结点,并给出当前串的长度。其结构用 C 语言定义如下: typedef struct { // 串的链表结构 Chunk *head, *tail; // 串的头和尾指针 int curlen; // 串的当前长度 } LString; 4.3 串的模式匹配算法 模式匹配 :子串定位运算。 (串匹配) 就是在主串中找出子串出现的位置。 用函数 Index(S, T, pos) 实现。 在串匹配中,将主串 S 称为目标(串), 子串 T 称为模式(串)。 如果在主串 S 中能够找到子串 T, 则称匹配成功, 返回第一个和子串 T 中第一个字符相等的字符在主串 S 中的序号;否则,称匹配失败,返回 0。 当用模式依次从目标的头部往后移,移到的位置就 叫位移,每次移动后要看模式里的字符和目标中相应的 字符是否相等,若都相等,这次位移就叫有效位移(其 实就是从这个位置开始的匹配成功),否则叫无效位移。 模式匹配是各种处理系统中最重要的操作之一,也 是一个比较复杂的串操作。模式匹配的算法不同,效率 将有很大差别。同一算法应用不同,效率亦有很大差别。 朴素的模式匹配算法 算法思想: 从主串 S 的第 pos 个字符起和模式 T 的第一个字符 比较之,若相同,则继续比较后续字符;否则从主串 S 的下一个字符起再重新和模式 T 的字符比较之。 例:S = ‘JINANSHI’,T = ‘NAN’。 J I N A N S H I N A N 不匹配 N A N 不匹配 N A N 匹配 N A N 匹配 匹配 3 当采用定长顺序存储结构时,实现此操作的算法如下: int Index(SString S, SString T, int pos) { i = pos; j = 1; while (i = S[0] j = T[0]) { if (S[i] == T[j]) { ++ i; ++ j; } // 继续比较后继字符 else { i = i – j + 2; j = 1; } // 指针后退重新开始匹配 } if ( j T[0]) return i -T[0]; else return 0; } // Index ▲ 总 结 4.2 串的存储表示 1.?串的定长顺序存储表示 2. 串的变长顺序存储(堆分配存储)表示 3. 串的块链存储表示

文档评论(0)

开心农场 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档