- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四章串与数组2011
第4章 串和数组;4.1 串
4.2 数组;4.1 串; 串一般记作:
s= “a1a2...an” (n?0)
其中,s是串的名称,用双引号(“”)括起来的字符序列是串的值;ai可以是字母、数字或其他字符;串中字符的数目n被称作串的长度。当n=0时,串中没有任何字符,其串的长度为0,通常被称为空串。
s1= “”
s2= “ ”
s1中没有字符,是一个空串;而s2中有两个空格字符,它的长度等于2,它是由空格字符组成的串,一般称此为空格串。
概念:
子串、主串:串中任意连续的字符组成的子序列被称为该串的子串。包含子串的串又被称为该子串的主串。;串中任意个连续字符组成的子序列称为该串的子串,包含子串的串相应地称为主串。通常将子串在主串中首次出现时的该子串的首字符对应的主串中的序号,定义为子串在主串中的序号(或位置)。例如,设A和B分别为
A=“This is a string” B=“is”
则B是A的子串,A为主串。B在A中出现了两次,其中首次出现所对应的主串位置是3。因此,称B在A中的序号(或位置)为3
特别地,空串是任意串的子串,任意串是其自身的子串。
通常在程序中使用的串可分为两种:串变量和串常量。串常量和整常数、实常数一样,在程序中只能被引用但不能不能改变其值,即只能读不能写。通常串常量是由直接量来表示的,例如语句Error(“overflow”)中“overflow”是直接量。但有的语言允许对串常量命名,以使程序易读、易写。如C++中,可定义
const char path[]=“dir/bin/appl”;
这里path是一个串常量,对它只能读不能写。串变量和其它类型的变量一样,其取值是可以改变的。; 例如,有下列四个串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 ”; 串的基本操作:
(1) 创建串 StringAssign (s,string_constant)
(2)判断串是否为空 StringEmpty(s)
(3)计算串长度 Length(s)
(4)串连接 Concat(s1,s2)
(5)求子串 SubStr(s1,s2start,len)
(6)串的定位 Index(s1,s2)
;
例1、求子串
求子串的过程即为复制字符序列的过程,将串S中的第pos个字符开始长度为len的字符复制到串T中。
void substr(string sub,string s,int pos,int len)
{
if(pos0 || posstrlen(s)-1 || len0)
error(“parameter error”)
strncpy(sub,s[pos],len);
}
;例2、串的定位index(s,t,pos)
在主串中取从第i个字符起、长度和串T相等的子串和T比较,若相等,则求得函数值为i,否则值增1直至S中不存在和串T相等的子串为止。
int index(string s,string t,int pos){
if(pos0){
n=strlen(s); m=strlen(t); i=pos;
while(in-m+1){
substr(sub,s,i,m);
if(strcmp(sub,t)!=0)
++i;
else return(i);
}
}
return
文档评论(0)