- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第4章 串和数组
本章教学提要
教学重点:字符串的概念及运算
数组(array)的概念及特点
教学难点:稀疏矩阵的存储及运算
本章教学内容
计算机不仅对能够处理数值对象,而且能够处理非数值对象,字符串数据的处理在非数值处理中占有重要的地位。字符串简称为串,如汇编语言的编译、文字编辑、信息检索系统、自然语言翻译系统及音乐分析程序等等,都是以字符串数据作为处理对象。
为了有效地处理字符串,必须根据具体情况使用合适的存储结构。本章将对串的存储结构进行研究。
4.1 串的运算
字符串(string)是一种简单的数据结构,它是由一个给定语言的字符集——又称字母表中的字符组成的有限序列。
字符串的运算:
1.连接(connection):把两个字符串首尾相连成一个字符串,即把第二个串紧接着放在第一个串的末尾,组成一个新串,用符号“‖”表示。
2.求子串(substring):一个串的子串就是串中的一个连续的子序列。即从该串中的第i个字符开始,取出连续j个字符组成的子串,其中字符串的序号从0开始。用sub(A,i,j)来表示求A的一个子串。
3.求串的长度(length):串的长度就是串中含有的字符个数,用len(A)来表示。
4.求子串在串中的序号(position):又叫串的模式匹配(运算),求子串在串中的位置,用position(A,B)来表示B在A中第一次出现的首字符的位置(序号,从0开始),结果为非负数或-1。若position(A,B)=-1,表示B不是A的子串。注意B不能是空串。
5.置换(replacement):把串中的子串用另一个串来替换。用repl(A,B,C)来表示,其含义是:如果B是A的子串,用C去取代原来A中所有的B,如果B不是A的子串,则repl(A,B,C)=A。注意B不能是空串。
6.删除子串(delete):从串中删除从第i个字符开始的长度为j的一个子串,用del(A,i,j)来表示。
7.插入(insert):在串的第i个字符之前插入B,用ins(A,i,B)来表示。
4.2 串的存储结构
串的顺序存储:类似于线性表的顺序存储,串中的字符序列被顺序地存放在一组地址连续的存储单元中。
串的链接存储:
类似于线性表的链式存储结构,串的链接存储结构是把可用存储空间分成大小相同的节点,逻辑上相邻的字符物理上是通过指针来链接的。链表的每个节点有两个域:值域(data域)和指针域(link域)。
顺序存储对访问子串运算较为方便,而且节省空间,而对插入和删除运算较为困难;链式存储插入和删除运算方便,但是可能浪费存储空间。
4. 3数组
数组中数据元素必定属于同一数据类型,数组元素的值和其下标是一一对应关系,而且数组下标具有上界和下界。
向量:指某一特定数域上由n个数组成的有序数组(a0,a1,…,an-1),其中ai(0≤i≤n-1)称为向量的分量。
矩阵:形如下列形式,Am×n矩阵有m行n列,可以看成一个二维数组:
a00 a01 … a0,n-1
Am×n= a10 a11 … a1,n-1
……
an-1,0 an-1,1 … am-1,n-1
二维数组Am×n来讲,则有两种顺序排列:即“行主序”和“列主序”。
行主序:就是将数组中元素按行向量排列,第i+1行向量紧排在第i个行向量后。
列主序:就是将数组中元素按列向量排列,第j+1个列向量紧接在第i个列向量之后。
数组不同于线性表,没有插入和删除运算
二维数组Am×n中的任意元素aij的(行主序)存储地址公式:
loc(aij)=loc(a00)+i×n+j
三维数组Am×n×u中的任意元素aijk的(行主序)存储地址公式:
loc(ai j k)=loc(a00)+i×m×n+j×n+k
矩阵中非零元素的个数远远小于零元素的个数时,我们称这样的矩阵为稀疏矩阵。
稀疏矩阵的两种存储方式,顺序存储和链接存储方式。
顺序存储:对于一个m行n列有t行非零元素的稀疏矩阵可用(t+1)个三列二维数组来表示,每行有3个存储单元,第0行3个存储单元分别存储矩阵的行数m和列数n和非零元素的个数t,第一行开始依次按照行主序方式存放三元组表中的每个元素。
链接存储:(带行指针向量的链接存储)把行号相同的三元组节点按照列数从小到大的顺序用指针连接成一个单链表。
2
您可能关注的文档
最近下载
- 招投标合规指引之招标常见问题(第一期).pdf VIP
- 2025版建筑行业临时用工合同范本(2025版).docx
- 痛风性关节炎-课件.ppt VIP
- 人教版二年级上册数学全册教学设计(配2025年秋新版教材).docx
- 2024年《高等教育心理学》教师岗前培训考试复习题库(含答案).docx VIP
- 四川省成都市双流区2024年小升初语文试卷 附解析.doc VIP
- Module4Unit1Willyoutakeyourkite?(教学设计)-英语四年级下册.docx
- 新闻编辑学 (第四版).pptx VIP
- 四川省成都市双流区2024年小升初语文试卷 附解析 .pdf VIP
- (人教2019版)化学必修第一册 全册大单元教学设计.docx
文档评论(0)