- 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章 数组和义表
第4章 数组、串与广义表 一维数组 定义 数组是相同类型的数据元素的集合,而一维数组的每个数组元素是一个序对,由下标(index)和值(value)组成。 一维数组的示例 在高级语言中的一维数组只能按元素的下标直接存取数组元素的值。 一维数组的定义和初始化 #include iostream main ( ) { int a[3] = { 3, 5, 7 }, *elem, i; //静态数组 for (i = 0; i 3; i++) cout a[i] endl; elem = new int[3]; //动态数组 for (i = 0; i 3; i++) cin elem[i]; while (elem) { cout *elem endl; elem++; } } 多维数组 多维数组的特点是每一个数据元素可以有多个直接前驱和多个直接后继。 例如二维数组的数组元素有两个直接前驱,两个直接后继,必须有两个下标(行、列)以标识该元素的位置。 行向量 下标 i 页向量 下标 i 列向量 下标 j 行向量 下标 j 列向量 下标 k 数组的连续存储方式 一维数组 二维数组 一维数组常被称为向量(Vector)。 二维数组 A[m][n] 可看成是由 m 个行向量组成的向量,也可看成是由 n 个列向量组成的向量。 一个二维数组类型可以定义为其分量类型为一维数组类型的一维数组类型: typedef T array2[m][n]; //T为元素类型 等价于: typedef T array1[n]; //行向量类型 typedef array1 array2[m]; //二维数组类型 同理,一个三维数组类型可以定义为其数据元素为二维数组类型的一维数组类型。 静态定义的数组,其维数和维界不再改变,在编译时静态分配存储空间。一旦数组空间用完则不能扩充。 动态定义的数组,其维界不在说明语句中显式定义,而是在程序运行中创建数组对象时通过 new 动态分配和初始化,在对象销毁时通过 delete 动态释放。 用一维内存来表示多维数组,就必须按某种次序将数组元素排列到一个序列中。 二维数组的动态定义和初始化 #include iostream.h ………… int **A; int row = 3, col = 3; int i, j; A = new int *[row]; for (i = 0; i row; i++) A[i] = new int [col]; for (i = 0; i row; i++) for (j = 0; j col; j++) cin A[i][j]; ………… 次序约定 以行序为主序 以列序为主序 特殊矩阵:指非零元素或零元素的分布有一定规律的矩阵 对称矩阵 三角矩阵 稀疏矩阵的压缩存储方法 顺序存储结构三元组表 求转置矩阵 问题描述:已知一个稀疏矩阵的三元组表,求该矩阵转置矩阵的三元组表 问题分析 一般矩阵转置算法: A = “This is a string” B = “is” 则 B 是 A 的子串,A 为主串。B 在 A 中出现了两次,首次出现所对应的主串位置是2(从0开始)。因此,称 B 在 A 中的位置为2。 特别地,空串是任意串的子串,任意串是其自身的子串。 C++有关字符串的库函数 #include string.h strcpy strncpy strcat strncat strlen strcmp 广义表是 n ( ≥0 ) 个表元素组成的有限序列,记作 LS (a1, a2, a3, …, an) LS 是表名,ai 是表元素,可以是表(称为子表),可以是数据元素(称为原子)。 n为表的长度。n = 0 的广义表为空表。 n 0时,表的第一个表元素称为广义表 的表头(head),除此之外,其它表元素组成的表 称为广义表的表尾(tail)。 广义表的特性 有次序性 有长度 广义表的表头与表尾 广义表的第一个表元素即为该表的表头,除表头元素外其他表元素组成的表即为该表的表尾。 广义表结点定义 结点类型 utype:= 0, 表头;= 1, 原子数据;
文档评论(0)