- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构第四章_串
数据结构与算法设计(Java版) 第1章 绪论 第2章 线性表 第3章 栈与队列 第4章 串 第5章 数组 第6章 树和二叉树 第7章 图 第8章 排序 第4章 串 4.1 串抽象数据类型 4.2 串的表示和实现 4.3 串的模式匹配 目的:串作为特殊线性表的实现与应用。 要求:掌握串的操作特点和实现方法,掌 握两种串的模式匹配算法。 重点:串的各种操作实现,两种串的模式 匹配算法。 难点:KMP模式匹配算法。 4.1 串抽象数据类型 4.1.1 串的基本概念 串定义、子串、串比较 4.1.2 串抽象数据类型 public interface SString { int length(); //返回串的长度 char charAt(int index); //返回串中序号为index的字符 SString concat(SString str); //当前串与str串连接生成新串 SString substring(int begin, int end); //返回串中字符序号从begin至end-1的子串 int indexOf(SString pattern); //返回pattern串在主串中的第一次匹配位置 } 4.2 串的表示和实现 4.2.1 串的存储结构 4.2.2 字符串类String 4.2.3 字符串类StringBuffer 4.2.1 串的存储结构 串的顺序存储结构 串的链式存储结构 4.2.2 字符串类String1.常量串的基本操作 图4.3 连接两个串常量 【例4.1】 String类的模拟实现。 public final class String1 { private final char[] value; } 【例4.2】 判断标识符。 2. String串的插入、删除操作 【例4.3】 使用String实现字符串的插入、删除操作。 4.2.3 字符串类StringBuffer 插入串 删除子串 【例4.4】 StringBuffer类的模拟实现。 public final class StringBuffer1 { private char[] value; //字符数组 private int n; //串的长度 } 【例4.5】 串的逆转。 4.3 串的模式匹配 4.3.1 朴素的模式匹配(Brute-Force)算法 4.3.2 无回溯的模式匹配(KMP)算法 4.3.1 朴素的模式匹配(Brute-Force)算法 【例4.7】 串的替换操作。 Brute-Force算法分析 目标串不必回溯 《数据结构(Java版)(第2版)》 4.3.2 无回溯的模式匹配(KMP)算法 KMP算法描述 2.求next数组 表4.1 模式串abcabc的next数组 j 0 1 2 3 4 5 模式串 a b c a b c next[j] ?1 0 0 0 1 2 KMP算法实现 计算next数组的算法 《数据结构(Java版)(第2版)》 5.改进next数组 5.改进next数组 表4.2 模式串abcabc改进的next数组 j 0 1 2 3 4 5 模式串 a b c a b c p0…pj?1中最长相同的前后缀子串长度k ?1 0 0 0 1 2 pk与pj比较 ≠ ≠ = = = 改进的next[j] ?1 0 0 ?1 0 0 6.KMP算法分析 * *
文档评论(0)