第4章 串和数组.ppt

  1. 1、本文档共17页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第4章 串和数组.ppt

第4章 串和数组 本章主要介绍下列内容: 串的定义、存储结构和基本运算; 数组的定义、基本运算和存储结构; 特殊矩阵的压缩存储。 4.1 串的基本概念 1 串的定义 串是字符串的简称。它是一种在数据元素的组成上具有一定约束条件的线性表,即要求组成线性表的所有数据元素都是字符,所以,人们经常又这样定义串: 串是由零个或多个任意字符组成的字符序列。 串一般记作: s= “a1 a2 ... an” (n?0) 其中,s是串的名称,用双引号(“”)括起来的字符序列是串的值;ai可以是字母、数字或其他字符;串中字符的数目n被称作串的长度。 当n=0时,串中没有任何字符,其串的长度为0,通常被称为空串。 s1= “” s2= “ ” s1中没有字符,是一个空串;而s2中有两个空格字符,它的长度等于2,它是由空格字符组成的串,一般称此为空格串。 2 几个术语 子串、主串:串中任意连续的字符组成的子序列被称为该串的子串。包含子串的串又被称为该子串的主串。 例如,有下列四个串a,b,c,d: a= “Welcome to Beijing b= “Welcome” c= “Bei” d= “welcometo” 子串的位置:子串在主串中第一次出现的第一个字符的位置。 两个串相等:两个串的长度相等,并且各个对应的字符也都相同。 例如,有下列四个串a,b,c,d: a=“program” b=“Program” c=“pro” d=“program” 4.1.2 串的基本运算 (1) 创建串 StrAssign (s1,s2) (2)判断串是否为空 StrEmpty(s) (3)计算串长度StrLength(s) (4)串连接 StrConcat(s1,s2) (5)求子串 SubStr(s,i,len) (6)串的定位 StrIndex(s1,t) 例:设字符串S1=“ABCDEFG”,S2=“PQRST”,则运算 S=Concat(Sub(S1,2,Length(S2)),Sub(S1,Length(S2),2)) 的结果是: 4.1.3 串的存储及基本运算的实现 1. 顺序存储结构 串的顺序存储结构与线性表的顺序存储类似,用一组连续的存储单元依次存储串中的字符序列。在C语言中,有两种实现方式: 第一种是事先定义字符串的最大长度,字符串存储在一个定长的存储区中。类型定义如下所示: #define MAXSIZE 255 char s[MAXSIZE]; 第二种是在程序执行过程中,利用标准函数malloc和free动态地分配或释放存储字符串的存储单元,并以一个特殊的字符作为字符串的结束标志,它的好处在于:可以根据具体情况,灵活地申请适当数目的存储空间,从而提高存储资源的利用率。类型定义,如下所示: typedef struct { char data[MAXSIZE]; int curlen; } SeqString; 定义一个串变量:SeqString s; 不同的定义形式,算法中的处理也略有不同。下面我们将给出在第一种顺序存储方式下串的几个基本操作的算法。 (1)串联接:把两个串s1和s2首尾连接成一个新串s ,即:s?s1+s2。 int StrConcat1(char s1[], char s2[], char s[]) { int i=0 , j, len1, len2; len1= StrLength(s1); len2= StrLength(s2); if(len1+ len2>MAXSIZE-1) return 0; /* s长度不够*/ j=0; while(s1[j]!=’\0’){ s[i]=s1[j];i++;j++;} j=0; while(s2[j]!=’\0’){ s[i]=s2[j];i++;j++;} s[i]=’\0’; return 1; } (2)子串 int StrSub (char *t, char *s, int i, int len) /* 用t返回串s中第个i字符开始的长度为len 的子串1≤i≤串长*/ { int

文档评论(0)

wsh1288 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档