- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第4章 串 《数据结构(C#语言描述)》配套PPT 北京大学出版社 制作:陈广 博客: 引入 串又称为字符串,是一种特殊的线性表。串的逻辑结构和线性表极为相似,区别仅在于串的数据对象为字符集。 串的基本操作和线性表有很大的区别 ,在线性表操作中,大多以“单个元素”作为操作对象;而在串的基本操作中,通常以“串的整体”作为操作对象。 4.1 串的基本概念 串又称为字符串,它是一种在数据元素的组成上具有一定约束条件的线性表,即要求组成线性表的所有数据元素都是字符。人们经常又这样定义串:串是由零个或多个字符组成的有限序列。串一般记作s=“a1a2···an”(n≥0),其中s是串的名称,用一对双引号括起来的字符序列是串的值。 4.1 串的基本概念 空串:不含任何字符的串称为空串 空格串:由一个或多个空格组成的串,称为空格串。 串相等:是指两个串的长度相等且对应的字符相等。 模式匹配:确定子串在主串中首次出现位置的运算。 子串:串中任意个连续的字符组成的子序列称为该 串的子串。 主串:包含子串的串称为该子串的主串。 4.2 String C#中使用System.String类型表示字符串。String类型是.NET中使用最频繁、应用最广泛的基本类型,因此CLR有针对性地对其性能采取了特殊的解决办法,这使得String成为一个很特殊的类型。 4.2 String String对象最重要的一个特点是:它是不可变的(immutable)。也就是说,字符串在创建之后就再也不能改变。任何对String的修改操作都会在托管堆中创建新的String对象 4.2 String String对象不可变性的优点: 保证对String对象的任意操作不会改变原字符串。 在操作或访问一个字符串时不会发生线程同步问题。 对于相同字符串,可以不为它们分配内存块,而使它们共享一块内存。这样能减少系统中字符串的数量,从而节省内存。 4.2 String String对象不可变性的缺点: 会在堆上创建大量的String对象,造成频繁的垃圾收集,从而妨碍应用程序的性能。 4.3 System.Text.StringBuilder 与String不同,System.Text.StringBuilder代表的是一个可变的字符串。也就是说StringBuilder中的大多数操作在更改字符数组内容的同时不会造成在托管堆上分配新的对象。 【例4-1 Demo4-1.cs】String和StringBuilder的性能对比 4.4 串的模式匹配 Brute-Force算法简称BF算法,也称为简单匹配算法。 4.4 串的模式匹配 BF算法简单,易于理解,但算法效率不高。 4.4 串的模式匹配 KMP算法是由D.E.Knuth与J.H.Morris、V.R.Pratt共同提出的,所以称为Knuth-Morris-Pratt算法,简称KMP算法 4.4 串的模式匹配 k=-1:只有模式串的第1个字符的k值为-1。 k0:表示指定字符前面k个字符和模式串的头k个字符相等。 k=0:其他情况。模式串的第2个字符的k值必为0 4.4 串的模式匹配 4.4 串的模式匹配 k=-1:只有模式串的第1个字符的k值为-1。 k0:表示指定字符前面k个字符和模式串的头k个字符相等。 k=0:其他情况。模式串的第2个字符的k值必为0 4.4 串的模式匹配 k=-1:只有模式串的第1个字符的k值为-1。 k0:表示指定字符前面k个字符和模式串的头k个字符相等。 k=0:其他情况。模式串的第2个字符的k值必为0 4.4 串的模式匹配 4.4 串的模式匹配 4.4 串的模式匹配 4.4 串的模式匹配 4.4 串的模式匹配 4.5 本章小结 * * Company LOGO 《数据结构(C#语言描述)》配套PPT 《数据结构(C#语言描述)》配套PPT 《数据结构(C#语言描述)》配套PPT 串的定义 1 《数据结构(C#语言描述)》配套PPT 基本概念 2 《数据结构(C#语言描述)》配套PPT 《数据结构(C#语言描述)》配套PPT 《数据结构(C#语言描述)》配套PPT 《数据结构(C#语言描述)》配套PPT 《数据结构(C#语言描述)》配套PPT 《数据结构(C#语言描述)》配套PPT 4.4.1 Brute-Force算法 c b b c b c b b c b c i j 《数据结构(C#语言描述)》配套PPT 4.4.1 Brute-Force算法 i j a a a a a b a a a a a a a a a b 《数据结构(C#语言描述)》配套PPT 4.4.2 KMP算法 《数据结构(C#语言描述)》配套PPT 4.4.2 KMP算法 a b c a b c a -1 0 0
文档评论(0)