数组的加减乘除计算

编辑
文档创建者:flyingsnake (65172 )     浏览次数:2636次     编辑次数:3次     最近更新:jiangsr 于 2018-07-25     

目录:

1. 引言编辑

帆软作为报表工具,在扩展展现的时候,经常会用到数组的知识。我们可以将帆软报表中每一个可以扩展的单元格都作为一个数组来考虑进行计算。而我们选择将扩展单元格列表显示的时候,相当于直接用“,”逗号做分割来展现了数组的各个元素。

很多的初学者对数组的运算存在一些错误认识,这里科普一下。

2. 数组的定义编辑

所谓数组,是相同数据类型的元素按一定顺序排列的集合。

若将有限个类型相同的变量的集合命名,那么这个名称为数组名。

组成数组的各个变量称为数组的分量,也称为数组的元素,有时也称为下标变量。

用于区分数组的各个元素的数字编号称为下标。

数组是在程序设计中,为了处理方便, 把具有相同类型的若干变量按有序的形式组织起来的一种形式。这些按序排列的同类数据元素的集合称为数组。

3. 数组的分类编辑

数组,就是元素的集合,按行、列进行排列。数组分为一维数组和多维数组。

单行或单列的数组,我们称为一维数组。   

多行多列(含2行2列)的数组是多维数组或二维数组。

4. 数组的运算编辑

一维数组和二维数组的运算规律   

1)单值x与数组arry运算    执行x与arry中每一个元素分别运算并返回结果,也就是与arry本身行列、尺寸一样的结果。    比如:2*{1,2;3,4;5,6},执行2*1、2*2、2*3、2*4、2*5、2*6运算,并返回3行2列的二维数组结果{2,4;6,8;10,12},如下图所示:

222

数组中行和列分别用逗号、分号来间隔。逗号表示行,行之间的关系比较紧密,用逗号分割;列之间,关系相对比较疏远一点,用分号分割。   

又比如:"A"&{"B","C"}返回{"AB","AC"}。"A"={"B","A","C"}返回{FALSE,TRUE,FALSE}

也就是说,数组是可以与单独字符或数值进行比较、合并、运算等处理的。

2)同向一维数组运算    执行arry1与arry2对应位置的元素分别运算并返回结果。要求arry1与arry2尺寸必须相同,否则多余部分返回#N/A错误。    

比如: {1;2;3}*{4;5;6}返回{4;10;18};  {1,2,3,4}*{4,5,6}返回{4,10,18,#N/A},如下图所示:

222

3)异向一维数组运算    arry1的每一元素与arry2的每一元素分别运算并返回结果,得到两个数组的行数*列数个元素,也就是M行数组与N列数组运算结果为M*N的矩阵数组。    比如:{1;2;3}*{4,5,6,7,8},执行1*4、1*5、1*6、1*7、1*8、2*4、2*5、2*6、2*7、2*8、3*4、3*5、3*6、3*7、3*8,返回{4,5,6,7,8;8,10,12,14,16;12,15,18,21,24} 
222

4)一维数组与二维数组运算    二维数组其中一个方向与一维数组同向同尺寸,比如M*N的二维数组与M行或者N列的数组运算,在同向的运算类似同向一维数组之间的位置对应,在异向的运算则类似单值与数组之间的一一运算。超出尺寸范围都返回错误值。  

 例:{1,2,3,4}*{1,2,3,4,5;6,7,8,9,10}即4列一维数组与2行5列二维数组运算,列方向上两个数组运算按位置一一对应的,不足部分用#N/A补齐,行方向上则是一对多的运算。  即:1*1,2*2,3*3,4*4,#N/A *5;1*6,2*7,3*8,4*9,#N/A *10;返回{1,4,9,16,#N/A;6,14,24,36,#N/A}。
222

5)二维数组之间运算    要求尺寸相同,并执行相同位置元素一一对应的运算,超出尺寸部分返回错误。   

例:{1,2;3,4}*{1,2,3;4,5,6;7,8,9}执行1*1,2*2,3*4,4*5,其余部分用#N/A补齐,返回={1,4,#N/A;12,20,#N/A;#N/A,#N/A,#N/A}

222





附件列表


主题: 专题总结
如果您认为本文档还有待完善,请编辑

文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

此页面有帮助吗?只是浏览 [ 去社区提问 ]