利用数组可以有效地存储和处理成批数据本章主要内容数组课件.ppt
《利用数组可以有效地存储和处理成批数据本章主要内容数组课件.ppt》由会员分享,可在线阅读,更多相关《利用数组可以有效地存储和处理成批数据本章主要内容数组课件.ppt(57页珍藏版)》请在三一办公上搜索。
1、第6章,数组,1,感谢你的观看,2019年8月21,利用数组可以有效地存储和处理成批数据 本章主要内容 数组的概念 数组的声明和应用 动态数组 For Each.Next循环语句 控件数组 程序举例,第6章 数 组,2,感谢你的观看,2019年8月21,6.1.1 数组与数组元素 简单变量用一个变量名标识,不同的变量使用不同的变量名表示。处理成批的数据时,必须使用数组来处理表示100个学生的成绩,采用简单变量来表示:s1,s2,s3,s99,s100 采用数组来表示:t(0),t(1),t(2),t(98),t(99)t(k)(k=0,1,2,99)为数组元素(或称下标变量),它表示第k个学生
2、的成绩,k称为下标变量的下标 数组的一个主要特点是通过下标(相当于索引)来引用数组元素,6.1 数组的概念,3,感谢你的观看,2019年8月21,例如计算这100个学生成绩的平均分,可用:S0 For k=0 To 99 S=S+t(k)累加分数 Next k Aver=S/100 求平均分,4,感谢你的观看,2019年8月21,数组是一组按一定顺序排列的数据的集合 例如,学生成绩t(0),t(1),t(99)是一个数组 三元一次方程组的系数矩阵 a11 a12 a13 A a21 a22 a23 a31 a31 a33 也是一个数组 数组名(不能与简单变量同名);数组类型,5,感谢你的观看,
3、2019年8月21,又称有序的变量下标变量 默认情况下,下标从0开始,option base n 必须在定义数组前使用。例如,由一行共5个元素组成的数组x,它的5个下标变量为:x(0)x(1)x(2)x(3)x(4)由三行四列元素组成的数组y,它的12个下标变量可表示为:y(0,0)y(0,1)y(0,2)y(0,3)y(1,0)y(1,1)y(1,2)y(1,3)y(2,0)y(2,1)y(2,2)y(2,3)下标变量与简单变量具有基本相同的性质和作用,数组元素,6,感谢你的观看,2019年8月21,下标用来标明该下标变量在数组中的位置 下标可以是常数值,也可以是变量(包括下标变量)或数值表
4、达式 例如:若x(2)=10,k=2,则y(x(2)就是y(10),y(x(2)+k)就是y(12)只要有规则地改变下标值,就可以很方便地使下标变量(如a(i)成为所需要的具体下标变量 数组的维数,6.1.2 下标和数组的维数,7,感谢你的观看,2019年8月21,6.2.1 数组声明语句 使用数组之前,一般需要定义数组,以便让系统分配相应的存储单元。格式为:Dim 数组名(下界1 to上界1,下界2 to上界2)As 数据类型 功能:指定数组的维数、各维的上下界和数据类型 举例:dim a%(10),b!(2 t0 8),c#(15),b(3,4)as Long Dim Sum(10)As
5、Long 下标号从010,共11个元素Dim Ary(1 to 20)As Integer 下标号从120,共20个元素Dim d(1 to 5,1 to 10)As Double 定义二维数组 dim c(-2 to 2)as string*20 还可以使用Public、Static、Private等语句来声明数组,6.2 数组的声明和应用,8,感谢你的观看,2019年8月21,数组下标测试函数,Ubound(数组名,维)Lbound(数组名,维)Dim y(1 to 12,5 to 20,-3 to 6)Print Lbound(y,1),Ubound(y,1)Print Lbound(y
6、,2),Ubound(y,2)Print Lbound(y,3),Ubound(y,3),9,感谢你的观看,2019年8月21,设定下界的方法 Option Base 1 设定下界为1 Dim Data(10)As Single 下标号从110 6.2.2 Array函数 使用Array函数可以为数组元素赋值 示例 Dim D As Variant 定义数组名(变体类型)D=Array(1,2,3,4)执行结果:1D(0),2D(1),3D(2),4D(3),10,感谢你的观看,2019年8月21,数组刷新语句可以作用于动态数组和静态数组 格式:Erase 数组名,数组名 功能:该语句用来清除
7、静态数组的内容,或者释放动态数组占用的内存空间 例如:Dim Array1(20)As Integer Dim Array2()As Single ReDim Array2(9,10)Erase Array1,Array2 对静态数组,Erase语句将数组重新初始化;对动态数组,Erase语句将释放动态数组所使用的内存,6.3.2 数组刷新语句(Erase),11,感谢你的观看,2019年8月21,Erase 数组名,数组名,重新对静太数组进行初始化,数值置0,字符为空字符串,而原数组存在。释放动态数组存储空间,原有数组不再存在。变体数组,每个元素重新置为空。,12,感谢你的观看,2019年8
8、月21,数组的引用和赋值:,Option Base 1 Dim B1 As VariantB1=Array(89,96,81,67,79,90,63,85,95,83)y=B1(3)C=B1(5)+B1(7)数组的引用下标不能越界数组的赋值:使用循环语句:,13,感谢你的观看,2019年8月21,dim k(10)For k=0 To 10 t(k)=2*k+1 Next kDim d(5)As Integer For i=1 To 5 输入成绩 d(i)=Val(InputBox(请输入第&Str(i)&_ 个学生的成绩,输入成绩)Next i,14,感谢你的观看,2019年8月21,数组输
9、出For i=1 To 5 Print d(i);Next i,15,感谢你的观看,2019年8月21,与前面的循环语句For.Next类似,都是用来执行指定重复次数的循环。但For Each.Next语句专门作用于数组或对象集合中的每一成员。语法格式:For Each 成员 In 数组名 循环体 Exit For Next 成员“成员”是一个Variant变量,它实际上代表数组中每一个元素 本语句可以对数组元素进行读取、查询或显示,它所重复执行的次数由数组中元素的个数确定 在不知道数组中元素的数目时非常有用,6.4 For Each.Next循环语句,16,感谢你的观看,2019年8月21,
10、Private Sub Form_Load()Dim a(1 To 10)As Long,sum As Long,t As Long Dim n As Integer Show t=1 For n=1 To 10 t=t*n a(n)=t Next n sum=0 For Each x In a sum=sum+x Next x Print 1!+2!+3!+10!=;sumEnd Sub,输出结果:1!+2!+3!+10!4037913,例6.6 求1!+2!+10!的值,17,感谢你的观看,2019年8月21,两种形式的数组:静态数组和动态数组 静态数组是指数组元素的个数固定不变;动态数组
11、的元素个数,在程序运行时可以改变 动态数组可以在运行过程中改变数组的大小,提高存储区的使用效率 6.3.1 建立动态数组 建立动态数组的步骤:第一步:声明一个没有下标(或称空维数)的数组为动态数组 第二步:在过程中用ReDim语句重新定义带下标的动态数组 ReDim语句格式:ReDim Preserve 数组名(下界1 T0 上界1,下界 T0 上界2)As数据类型 功能:重新定义动态数组,按定义的上下界重新分配存储单元,6.3 动态数组,18,感谢你的观看,2019年8月21,声明F为动态数组的示例:Private Sub Command1_Click()Dim F()As Integer
12、声明一个整型动态数组 Size=20 ReDim F(Size)End Sub 每次执行ReDim时,系统会清除指定数组的内容 若采用:ReDim Preserve F(Size)则能保留数组中原有的数据,19,感谢你的观看,2019年8月21,Private Sub Form_Load()Dim a()As Integer Show ReDim a(800)k=0 For x=200 To 600 Step 3 If x Mod 8=0 Then k=k+1 a(k)=x End If Next x ReDim Preserve a(k)For i=1 To k Print a(i)Next
13、 iEnd Sub,例6.5 ReDim语句应用示例,20,感谢你的观看,2019年8月21,两类数组:一般数组和控件数组 6.5.1 控件数组的概念 控件数组是一组具有相同名称、类型和事件过程的控件 例如,Label1(0),Label1(1),Label1(2),但Label1,Label2,Label3,不是控件数组 控件数组具有以下特点:(1)相同的控件名称(即Name属性);(2)控件数组中的控件具有相同的一般属性;(3)所有控件共用相同的事件过程。以下标索引值(Index)来标识各个控件,第一个下标索引号为0,6.5 控件数组,21,感谢你的观看,2019年8月21,6.5.2 控
14、件数组的建立,建立控件数组有三种方法:(1)给控件起相同的名称(2)将现有的控件复制并粘贴到窗体等上面(3)将控件的Index属性设置为非Null数值 6.5.3 控件数组的使用,22,感谢你的观看,2019年8月21,例6.7 按图6.4设计窗体,其中一组(共5个)单选按钮构成控件数组,要求当单击某个单选按钮时,能够改变文本框中文字的大小,控件数组,23,感谢你的观看,2019年8月21,设计步骤:(1)设计控件数组Option1,其中包含5个单选按钮对象 具体操作方法:画出第一个单选按钮控件,名称采用默认的Option1。此时该控件处于选定状态。单击工具栏上的“复制”按钮(或按Ctrl+C
15、)。单击工具栏上的“粘贴”按钮(或按Ctrl+V),此时系统弹出一个如图6.5所示的对话框 单击“是”,就建立一个控件数组元素,其Index属性为1,而已画出的第一个控件的Index属性值为0。通过鼠标拖放可以调整新控件的位置,24,感谢你的观看,2019年8月21,继续单击“粘贴”按钮(或按Ctrl+V)和调整控件位置,可得到控件数组中的其他三个控件,其Index属性值分别为2,3和4(即从上而下为0,1,2,3,4)设置控件数组各元素(从上而下)的Caption属性分别为10,14,18,24和28(2)建立一个文本框Text1,其Text属性设置为“控件数组的使用”。再建立一个标签,其C
16、aption属性为“字号控制”(3)编写程序代码,25,感谢你的观看,2019年8月21,Private Sub Form_Load()Option1(0).Value=True 选定第一个单选按钮 Text1.FontSize=10 设定文本框中的字号End SubPrivate Sub Option1_Click(Index As Integer)Select Case Index 系统自动返回Index值 Case 0 Text1.FontSize=10 Case 1 Text1.FontSize=14 Case 2 Text1.FontSize=18 Case 3 Text1.Font
17、Size=24 Case 4 Text1.FontSize=28 End Select End Sub,26,感谢你的观看,2019年8月21,例6.1 输入某小组5个同学的成绩,计算总分和平均分(取小数后一位)本例利用InputBox函数来输入成绩,输入完毕后经过计算,再采用Print直接在窗体上输出结果,6.2.3 数组的应用,27,感谢你的观看,2019年8月21,Private Sub Form_Load()Dim d(5)As Integer Dim i As Integer,total As Single,average As Single Show For i=1 To 5 输入
18、成绩 d(i)=Val(InputBox(请输入第&Str(i)&_ 个学生的成绩,输入成绩)Next i total=0 For i=1 To 5 计算总分和平均分 total=total+d(i)Next i average=total/5 Print 总分:&total Print 平均分:&Format(average,#.0)End Sub,28,感谢你的观看,2019年8月21,程序中,先通过Dim语句为数组d定义维数及下标范围,也即为数组安排一块连续的内存存储区,但这并不意味着内存里该数组已建立了应有的内容 本例中输入数组中的数据是由InputBox函数来实现的,共循环了五次,输
19、入的五个数依次赋值给下标变量d(1)d(5)建立了数组中的数据后,就可以按要求进行处理,29,感谢你的观看,2019年8月21,(1)创建应用程序的用户界面和设置对象属性,例6.2 输入10名学生的成绩,求出最高分和最低分,30,感谢你的观看,2019年8月21,功能要求:通过Array函数输入10个分数;单击“查找”按钮(Command2)后,开始查找最高分和最低分,找到后显示在标签Label1上 Option Base 1 Dim score As Variant Private Sub Form_Load()Label1.Caption=单击“查找”按钮开始查找最高分和最低分 score
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 利用 数组 可以 有效地 存储 处理 成批 数据 本章 主要内容 课件
链接地址:https://www.31ppt.com/p-3875102.html