第 4 章 字符串和多维数组,本章的基本内容是:字符串。在程序设计语言中大都有串变量的概念,而且实现了基本的串操作,本章重点讨论串的存储结构及模式匹配算法。数组。在程序设计语言中大都提供了数组作为构造数据类型,本章重点讨论数组以及特殊矩阵的存储与寻址。,线性表具有相同类型的数据元素的有限序列。,限制
3数组枚举结构字符串Tag内容描述:
1、将元素类型扩充为线性表,第 4 章 字符串和多维数组,将元素类型限制为字符,4.1 字符串,串的逻辑结构,非空串通常记为:S=“ s1 s2 sn “ 其中:S是串名,双引号是定界符,双引号引起来的部分是串值 ,si(1in)是一个任意字符。
,串:零个或多个字符组成的有限序列。
串长度:串中所包含的字符个数。
空串:长度为0的串,记为:“ “。
,S1=“ab12cd “ S2=“ab12“ S3=“ab13“ S4=“ab12“ S5=“ “ S6=“ “,串的逻辑结构,子串:串中任意个连续的字符组成的子序列。
主串:包含子串的串。
子串的位置:子串的第一个字符在主串中的序号。
,4.1 字符串,串的逻辑结构,串的数据对象约束为某个字符集。
微机上常用的字符集是标准ASCII码,由 7 位二进制数表示一个字符,总共可以表示 128 个字符。
扩展ASCII码由 8 位二进制数表示一个字符,总共可以表示 256 个字符,足够表示英语和一些特殊符号,但无法满足国际需要。
Unicode由 16 位二进制数表示一个字符,总共可以表示 216个字符,能够表示世界上所有语言的所有字。
2、3.1 朴素的模式匹配 3.3.2 无回溯的模式匹配,3.1 字符串及其抽象数据类型,3.1.1 基本概念字符串简称串,是一种特殊的线性表,其特殊性主要在于表中的每个元素是一个字符。
一个串可以记作s=“s0s1sn-1“(n 0),其中s是串的名字,双引号括起来的字符序列s0s1sn-是串的值。
例如: A = “123“ B = “ABBABBC“ C = “BB“ D = “BB “ E = “,一个串中包括的字符个数称作这个串的长度。
长度为零的串称为空串,它不包括任何字符,写作s=“”。
空字符也是一个字符,由一个或多个空字符构成的字符串“ ”不是空串。
字符串s1中任意个连续的字符组成的子序列s2被称为是s1的子串,而称s1是s2的主串。
特别地,空串是任意串的子串。
任意串s都是s本身的子串。
除s本身之外,s的其它子串称为s的真子串。
子串在主串中的位置指的是该子串的第一个字符在主串中的位置。
,3.1.2 抽象数据类型,ADT String is operations String createNullStr (void)创建一个空串。
int IsNullS。
3、串 单元数组 结构体,2019年3月2日,第5页,字符串的生成(1/2),字符串的生成 MATLAB 中的字符串为 ASCII 值的数值数组,作为字符串表达式进行表示。
在 MATLAB 中,生成字符串的方法为 stringname=the content of the string。
,2019年3月2日,第6页,字符串的生成(2/2),字符串是一个 ASCII 码的字符数组,因此,与普通数组一样,字符串也可以形成矩阵(表现为一个字符串有多行)。
但是,这些行必须有相同数目的列数。
另外,使用 char 函数可以创建长度不一致的字符串矩阵。
char 函数自动将所有字符串的长度设置为输入字符串中长度的最大值。
,2019年3月2日,第7页,字符串的操作,字符串的显示字符串的显示有两种方式:直接显示和利用 disp 函数进行显示。
字符串的执行在 MATLAB 中可以用函数 eval 来执行字符串。
,2019年3月2日,第8页,字符串的运算,字符串的运算主要包括: 判断字符串是否相等 通过字符串运算来比较字符串中的字符 进行字符分类、查找与替换 字符串与数值数组之间的相互转换,2019年3月。
4、数组元素都必须具有相同的类型,即每个数组元素都占据相同大小的存储空间.,数组在内存中一般是以顺序方式存储的.设一维数组An存放在n个连续的存储单元中,每个数组元素占一个存储单元(不妨设为C个连续字节). 如果数组元素A0的首地址是L,则A1的首地址是L+C,A2的首地址是L+2C, ,依次类推,对于 有:对于高维数组,可将其转化为一维数组来考虑. 高维数组存在着两种存储方式按行优先顺序和按列优先顺序。
,所谓按行优先顺序,就是将数组元素按行向量的顺序存储,第 个行向量存储在第 个行向量之后。
换句话说,就是将数组转化为一维数组 来考虑。
以按行优先顺序存储的二维数组 为例,它可以被看作一个一维数组 ,其中Bi是由 的第 行的n个元素构成的一个一维数组(第 个行向量),即 Bi= Ai0,Ai1,Ain-2,Ain-1 ,下面我们计算二维数组Amn中任一元素Aij的存储地址,设每个数组元素所占空间为C个连续字节,有再例如三维数组D3。
5、将元素类型扩充为线性表,第 4 章 字符串和多维数组,将元素类型限制为字符,4.1 字符串,串的逻辑结构,非空串通常记为:S=“ s1 s2 sn “ 其中:S是串名,双引号是定界符,双引号引起来的部分是串值 ,si(1in)是一个任意字符。
,串:零个或多个字符组成的有限序列。
串长度:串中所包含的字符个数。
空串:长度为0的串,记为:“ “。
,S1=“ab12cd “ S2=“ab12“ S3=“ab13“ S4=“ab12“ S5=“ “ S6=“ “,串的逻辑结构,子串:串中任意个连续的字符组成的子序列。
主串:包含子串的串。
子串的位置:子串的第一个字符在主串中的序号。
,4.1 字符串,串的逻辑结构,串的数据对象约束为某个字符集。
微机上常用的字符集是标准ASCII码,由 7 位二进制数表示一个字符,总共可以表示 128 个字符。
扩展ASCII码由 8 位二进制数表示一个字符,总共可以表示 256 个字符,足够表示英语和一些特殊符号,但无法满足国际需要。
Unicode由 16 位二进制数表示一个字符,总共可以表示 216个字符,能够表示世界上所有语言的所有字。
6、bc def”就是长度为7的字符串,s3=“ ”是长度为8的字符串。
,字符串,相关概念子串-有一个串S,称S中的一个连续段所组成的串为S的子串。
主串-包含子串的S串称为子串的主串。
例:设串S=“abcdefghijk” , S1=“cdef” , S2=“abc12”S3=“” , S4=“123 ab”其中S1是S的子串,则S是主串,但S2、S3、S4不是S的子串。
子串的位置-子串在主串中第一次出现时其第一个字符的位置。
例如S1在S中出现的位置是串相等-两个串的长度相等,并且各个对应的字符也都相同。
,字符串,串的基本操作串的长度StrLenth(s);判断两个串是否相等StrEqual(s,t);两个串的连接StrConcat(s1,s2);求某串的子串subStr(s,i,len);插入子串StrInsert(s1,i,s2);串的定位 StrIndex(s1,t); 判断串是否为空StrEmpty(s);,可能在C语言中,对于字符串的某些操作由系统函数就可以实现,但是不保证所有的语言都有相应的函数可调用,所以对于字符串的基本操作过程必须要明白。
7、00a00“;int i,j; i=sizeof(a); j=strlen(a); printf(“%d %dn“,i,j); 程序运行后的输出结果是 C A)2 2 B)7 6 C)7 2 D)6 2 (25)以下能正确定义一维数组的选项是 B A)int a5=0,1,2,3,4,5; B)char a=0,1,2,3,4,5; C)char a=A,B,C; D)int a5=“0123“;,(27)已有定义:char a=“xyz“,b=x,y,z;以下叙述中正确的是 C A)数组a和b的长度相同 B)a数组长度小于b数组长度 C)a数组长度大于b数组长度 D)上述说法都不对,指出下面各说明语句中哪些是合法的: BA. int abcd0x80; B. char 9ab10; C. char chi-200; D. int aaa5=3,4,5;E. flo。
8、第3章字符串数组特殊矩阵,字符串数组,字符串转数组,js数组转字符串,字符串数组初始化,定义字符串数组,java字符串数组,c语言字符串数组,字符数组转化为字符串,二维字符串数组。
9、MATLAB字符串单元数组和结构,字符串数组,字符串转数组,js数组转字符串,字符串数组初始化,定义字符串数组,java字符串数组,c语言字符串数组,字符数组转化为字符串,二维字符串数组。
10、 45, 45, 68, -1, 0 ;,注意二维数组的声明: Int , num=new int3,4;,数组示例,学生分数的整数数组,职员姓名的字符串数组,室温的浮点数组,数组位置,数组演示,static void Main(string args) int count;Console.WriteLine(“请输入您要登记的学生人数 “);count=int.Parse(Console.ReadLine();/ 声明一个存放姓名的字符串数组,其长度等于提供的学生人数 string names = new stringcount;/ 用一个 for 循环来接受姓名 for(int i=0; icount; i+)Console.WriteLine(“请输入学生 0 的姓名 “,i+1);namesi=Console.ReadLine();Console.WriteLine(“已登记的学生如下: “);/ 用 foreach 循环显示姓名 foreach(string disp in names)Console.Wri。