vb程序设计教程课后答案与实验题答案(第三版)

更新时间:2024-04-20 20:30:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

习题一

答案在教材上找。

习题二

1.对象指现实世界中的实体。每个对象有自己的特征(属性)、行为(方法)和发生在该对象上的活动(事件)。

类是对同一种对象的集合与抽象。类包含所创建对象的属性数据,以及对这些数据进行操作的方法。封装和隐藏是类的重要特性,将数据结构和对数据的操作封装在一起,类的内部实现细节对用户来说是透明的。

VB工具箱中的可视图标是VB系统设计好的标准控件类。通过将控件类实例化,得到真正的控件对象。在窗体上画一个控件,就将类转换为对象,创建了一个控件对象。

VB中常用的对象是控件。此外,VB还提供了系统对象。窗体是个特例,它既是类也是对象。当向一个工程添加一个新窗体时,实质就由窗体类创建了一个窗体对象。

对象的三要素:属性、事件和方法。 属性:存放对象的数据(决定对象外观及功能)对象属性的设置方法:在设计阶段,利用属性窗口直接设置属性值;程序运行时,通过语句[对象名.]属性名=属性值。若属性只能在设计阶段设置,在程序运行阶段不可改变,称为只读属性。 事件:发生在对象上的事情。同一事件,对不同的对象,会引发不同的反应。 事件过程:应用程序处理事件的步骤。应用程序设计的主要工作就是为对象编写事件过程的代码。 方法:面向对象的程序设计语言,为程序设计人员提供了一种特殊的过程和函数。方法是面向对象的,调用时一定要指明对象。

2.窗体和控件具有的基本属性“ (1) Name属性:名称

所创建的对象名称,在程序中引用。 (2) Caption属性:标题

该属性决定了对象上显示的内容。 (3) Height、Width、Top和Left属性 决定对象的大小和位置。

(4) Enabled 属性:对象是否允许操作 (5) Visible 属性:对象是否可见 (6) Font 属性组:文本的外观

FontName字体、FontSize大小 FontBold粗体、FontItalic斜体 FontStrikethru 删除线 FontUnderline 下划线 (7) ForeColor属性:前景颜色 (8) BackColor属性:背景颜色

(9) MousePointer属性:鼠标指针类型, 设置值范围0~15,由系统指定 。若为99,由用户提供的图形文件定义鼠标指针形状。

(10) MouseIcon属性:在MousePointer属性值为99时,存放自定义的鼠标图标文件(.ico或.cur)。图标库在Graphics目录下。

3.窗体的事件:Load事件是在窗体被装入工作区时触发的事件。当应用程序启动,自动执行该事件,该事件通常用来在启动应用程序时对属性和变量进行初始化。

窗体的方法:(1)Print方法

用来显示文本内容,格式:[对象.]print 表达式 (2)Cls方法

清除运行时在窗体或图形框中产生的文本或图形, Cls方法不能清除窗体在设计时的文本和图形。 格式:[对象.]cls (3)Move方法

可移动窗体或控件,并可改变其大小。 语法格式如下:

[对象.]Move 左边距离[,上边距离[,宽度[,高度]]]

4.标签作用:用于显示文本(输出)信息,不能作为输入信息的界面。其内容只能通过Caption属性设置或修改,不能直接编辑。

5.文本框是一个文本编辑区域,可以在该区域输入、编辑、修改和显示正文内容。在VB中字符长度以字为单位,也就是一个西文字符与一个汉字都是一个字,长度为1。

重要属性(1) Text 显示或输入的正文内容。

(2) Maxlength 设置文本框可输入的文字最大长度。默认值为0,表示可以输入任意长字符串。

(3) MultiLine 多行属性

设置为True时,文本框可以输入或显示多行正文,同时具有文字处理器的自动换行功能,按Enter键可插入一空行。 (4) ScrollBars 滚动条属性 0-None 无滚动条 1-Horizontal 水平滚动条 2-Vertical 垂直滚动条

3-Both 同时加水平和垂直滚动条

注意:当MultiLine为True时,ScrollBars才有效

(5) PassWordChar 设置显示文本的替代符。例如,当设置为“*”,则在文本框输入的内容均以“*”显示,而存储的值是用户输入的原文。一般用于设置口令的输入。

当MultiLine为True时,该属性不起作用,密码不允许多行。

(6) Locked 指定文本控件是否可被编辑,默认值为False(可编辑),当设置为True时,文本控件相当于标签控件的作用。 注意:Locked与Enabled的区别。 (7)文本内容进行选择操作的三个属性

SelStart 选定的正文开始位置 SelLength 选定的正文长度 SelText 选定的正文内容

这3个属性互相关联,例如设置SelStart、SelLength后,SelText 自动存放指定的文本。

注意:属性窗口中没有这三个属性,只能在程序代码中使用。

6.文本框的事件:(1) Change事件:当Text属性值发生改变时引发该事件 (2) KeyPress事件:按下并且释放键盘上的一个键时,引发焦点所在控件的KeyPress事件,所按键的值存放在参数KeyAscii中。对回车的判断 KeyAscii=13

7.文本框最有用的方法是SetFocus,把光标移到指定的文本框中。

8.命令按钮 Picture属性:按钮可显示图片文件(.bmp和.Ico),当Style为1时有效。

10. 启动窗体时将命令按钮定位在窗体中央的代码

Private Sub Form_Load()

Command1.Left = Form1.ScaleWidth / 2 - Command1.Width / 2

Command1.Top = Form1.ScaleHeight / 2 - Command1.Height / 2

End Sub

11.vb图片文件在 C:\\Program Files\\Microsoft Visual Studio\\Common\\Graphics 文件夹。

安装VB时可选择是否安装这些图片文件。

习题三

1. 合法常量:

(1) Double

(2) 错误

(3) Double

(4) Double

(5) 错误

(6) Integer

(7) String

(8) String

(9) Date

(10) Double

(11) 错误(汉字字符)

(12)Integer(八进制)

(13) 错误(八进制无数码8)

(14) Integer

(15) Boolean

(16) 错误

(17) 错误(十六进制无数码g)

(18) Single

说明:浮点型变量默认为Double类型而非Single。

2. 合法变量名:

(1) √

(2) √

(3) 误:数字开头

(4) 误:含空格

(5) 误:关键字

(6) √

(7) 误:关键字

(8) 误:有括号

(9) √

(10) √

(11) √

(12) √(汉字字符可作为变量名,但不常用,且此名称易误解)

变量命名规则见P.41-42。

字母(汉字)开头,字母(汉字)、数字、下划线组成,长度为1-255个字符;关键字不可作为变量名,但可在变量名中嵌入关键字;不区分大小写。

常量、数组、类型、函数、过程、对象命名规则与此相同。常量名通常全用大写。

3. 写VB表达式

(1) Abs(x + y) + z ^ 5

(2) (1 + x * y) ^ 6

(3) (10 * x + Sqr(3 * y)) / (x * y)

(4) (-b + Sqr(b ^ 2 - 4 * a * c)) / (2 * a)

(5) 1 / (1 / r1 + 1 / r2 + 1 / r3)

(6) Sin(45 * 3.14159 / 180) + (Exp(10) + Log(10)) / Sqr(x + y + 1)

4. 根据条件写表达式

(1) 随机产生大写字母 Chr(Int(Rnd * (Asc(\

(2) [100,200]内的随机数 Int(Rnd * 101) + 100

(3) 点(x,y)位于第一或第三象限 x > 0 And y > 0 Or x < 0 And y < 0 或 x * y > 0

(4) x是5或7的整数倍 x Mod 5 = 0 Or Int(x / 7) = x / 7

(5) 将两位整数x的个位与十位对换 x \\ 10 + (x Mod 10) * 10

(6) 四舍五入取两位小数 Round(x, 2)

(7) 字符变量C是字母字符(不区分大小写)——准确地说是:字符变量C的第一个字符是字母

C >= \

或 UCase(C) >= \

或 LCase(C) >= \

(8) 字符变量S第5个字符起取6个字符 Mid(S, 5, 6)

(9) 10≤x<20 10 <= x And x < 20

(10) x,y至少有一个小于z x < z Or y < z

(11)x,y都大于z x > z And y > z

5. 写表达式的值

(1) 188 ——注意运算的优先级顺序,以及整除运算“\\”的计算

(2) 200100 —— 计算100 + \时,由于两个操作数类型不同,在可能的情况下自动采用精度较高的类型,即把字符型转换为数值型,100 +100 得到200;然后进行字符串连接运算200 & 100 ,再自动将两个数值转换为字符串,得200100。

(3) 68.56 ——在四舍五入函数产生之前,这就是四舍五入的计算方法

(4) 876554 ——先进行字符串的“+”运算,再转换成数值。在变量名和函数名后可加上类型符,以强调其类型,但不是必须的。

(5) 2000-2-29

(6) 6

6.Shell函数调用

i = Shell(\ '启动画图

i = Shell(\ '启动Word

说明:“画图”是Windows本身提供的程序,可以省略路径。

8. 答:单精度浮点型

第7,9题答案在教材中找。

习题四

第1,3,5,8题答案在教材中找。

2. 赋值语句的错误

(1)10x 不能做变量名。

上机验证结果:VB将10识别为行号,x = Sin(x) + y是为变量x赋值。故无语法错误。

(2)Sqr函数的参数为负数。

上机验证结果:“无效的过程调用或参数”

(3)赋值号左边不是变量名。

上机验证结果:“缺少子程序、函数或属性”

(4)除数为0

上机验证结果:“溢出”。

4. [答案略]

说明:小数位可以使用四舍五入函数Round或输出格式函数Format。例如Round(x, 2)和Format(x, “0.00”)均可使结果只保留两位小数。但如果四舍五入后要进行数值运算,则使用Round函数,例如z=Round(x,2)+Round(y,2)。而Format函数通常只用于输出格式设置。

6.指出错误

(1)“≥”应改为“>=”,前者是中文字符,不具有运算功能。

(2)“10

7.写条件语句

(1)

Dim c As String c = InputBox(\

If Mid(c, 3, 1) = \ MsgBox \Else

MsgBox \End If

(2)

# 使用If语句

Dim x As Single, y As Single x = Val(InputBox(\If x > 20 Then

y = x ^ 2 + 3 * x + 2 ElseIf x >= 10 Then y = Sqr(3 * x) - 2 ElseIf x > 0 Then

y = 1 / x + Abs(x) End If

Print \

# 使用Select Case语句 Dim x As Single, y As Single x = Val(InputBox(\Select Case x Case Is > 20

y = x ^ 2 + 3 * x + 2 Case Is >= 10

y = Sqr(3 * x) - 2 Case Is > 0

y = 1 / x + Abs(x) End Select Print \

(3)

# 使用If语句

Dim x As Single, y As Single, z As Single, Max As Single x = Val(InputBox(\y = Val(InputBox(\z = Val(InputBox(\Max = x

If y > Max Then Max = y If z > Max Then Max = z Print \

# 使用IIF函数

x = Val(InputBox(\y = Val(InputBox(\z = Val(InputBox(\Max = IIf(x > y, x, y)

Max = IIf(z > Max, z, Max) Print \

9. 计算循环次数

(1) 6 (2)19 (3)0

(4)死循环直至溢出

10. 40号语句执行 4次;第50 号语句执行12次;

执行第90号语句输出的结果是: 13,0,2

说明:该程序为嵌套循环,其中外循环由j值变化(1,4,7,10)控制执行4次,当j值为13时结束循环;内循环由k值变化(6,4,2)控制执行3次,当k值为0时结束循环。第40 行是外循环的循环体,故执行4次;第50 行是内循环的循环体,故执行4*3=12次。

11. 可以定一个较大的循环次数,在循环体中根据条件用Exit For退出。

但这种情况通常用Do While循环控制。

12. 编程(并非唯一正确答案)

(1)

Dim i As Integer, s As Integer For i = 1 To 10

s = s + (i + 1) * (2 * i + 1) Next i

Print \

(2)

Dim i As Integer, n3 As Integer, n7 As Integer For i = 1 To 100

If i Mod 3 = 0 Then n3 = n3 + 1

If Int(i / 7) = i / 7 Then n7 = n7 + 1 Next i

Print \中3的倍数有\个\Print \中7的倍数有\个\

(3)

Dim s1 As String, s2 As String, i As Integer s1 = InputBox(\s2 = \

For i = 1 To Len(s1)

s2 = Mid(s1, i, 1) + s2 Next i

Print \原序:\Print \反序:\ 或

For i = Len(s1) To 1 Step -1 s2 = s2 + Mid(s1, i, 1) Next i

13. 输出字符串“10100”。该程序功能是将十进制数转化为二进制。

说明:要理解该程序需要了解数制转换的计算方法(有兴趣者参看百度百科http://baike.http://m.wodefanwen.com//view/1426817.htm)。48是字符\的ASCII码。

14. 运行时输出 22 484

该程序功能是求x和y最大公约数和最小公倍数。

说明:此算法称为“辗转相减法”。可对照例4.17的辗转相除(辗转求余)法。

15.[50,100]间的20个随机数,求最大值、最小值、平均值。

Dim x As Integer, sum As Integer, aver As Single Dim n%, i%, max%, min% Randomize

max = 50: min = 100: n = 20

For i = 1 To n

x = Int(Rnd * 51 + 50) List1.AddItem x sum = sum + x

If x > max Then max = x If x < min Then min = x Next i

aver = sum / n

Print \最大值:\最小值:\平均值:\

习题五

1. 指定数组的默认下界 Option Base 1

2.合理的数组声明

(1)错。定义数组不可用变量(教材99页)。 (2)正确。该数组下标为0-11。 (3)错。VB中数组下标用圆括号。

(4)正确。三维数组三个下标分别为0-1,0-1,0-2,共12个元素。 (5)错误。非动态数组,不可重定义。

(6)错误。动态数组重定义时不可改变数据类型。

(7)正确。二维数组两个下标分别为0-2,0-3,共12个元素。

(8)语法错误,二维数组定义中漏写逗号——可能是印刷错误,加上此逗号则正确。 3.当引用数组元素时下标值小于定义的最小下标,或大于最大下标时,会发生“下标越界”错误。

4.数组名:a ;数组类型:Single(单精度浮点型);维数:二维; 各维的上下界:第一维下界(最小下标)为 -1,上界(最大下标)为2, 第二维下界(最小下标)为 0,上界(最大下标)为3; 数组的大小:4行4列共16个元素 以矩阵的格式输出二维数组: For i = -1 To 2 For j = 0 To 3 Print a(i, j); Next j Print Next i

或写成更加通用的代码形式:

For i = LBound(a, 1) To UBound(a, 1) For j = LBound(a, 2) To UBound(a, 2) Print Tab(j * 8); a(i, j); Next j

Print Next i

6.一维字符数组

Dim a(1 To 20) As String

Private Sub Command1_Click() '(1)随机产生字符串

Dim i As Integer, j As Integer, n As Integer, c As String * 1 Randomize For i = 1 To 20

a(i) = \ '将第i个元素清空

n = Int(Rnd * 10 + 1) '产生[1,10]的随机数 For j = 1 To n 'a(i)中有n个字符

c = Chr(Int(Rnd * 26 + 97)) '随机产生字母97是字母a的ASCII码

a(i) = a(i) + c Next j Next i End Sub

Private Sub Command2_Click() '(2)输出字符串 Dim i As Integer For i = 1 To 20

Print Tab(((i - 1) Mod 5) * 11); a(i); If i Mod 5 = 0 Then Print Next i End Sub

Private Sub Command3_Click() '(3)最长的字符串 Dim i As Integer, imax As Integer imax = 1

For i = 2 To 20

If Len(a(i)) > Len(a(imax)) Then imax = i End If Next i

Print \最长的字符串:\End Sub

第7,8题答案在教材中找。

第9题“自定义变量”含义不明,暂时无法回答。

第5,10 题 [暂略]

习题六

第1,2,6-8题答案可在教材中找到。

3.指出过程说明中的错误

(1)Sub子过程不应该定义类型 (2)函数与形式参数不应该同名

(3)数组作为形式参数时,应使用传地址方式,不可使用传值(ByVal) (4)形式参数应该是变量或数组名,不可以是一个数组元素

4.指出调用过程语句的错误

(1)无语法错误,但因形参sum所对应的实参是常量3,故计算结果无法传递给主调程序。

(2)实参变量c与形参sum的类型不一致。

(3)类似于(1),形参sum所对应的实参是表达式a+b,故计算结果无法传递给主调程序。

(4)类似于(1)和(2),形参sum所对应的实参是表达式Sqr(c),故计算结果无法传递给主调程序。另外srq(a)存在语法错误(拼写错)。 (5)与(2)相同,实参c与形参sum的类型不一致。

5.迭代法求平方根

(1)自定义函数的定义及调用

Function FSqr1(a As Single) As Single Dim x0 As Single, x As Single x = a Do

x0 = x

x = (x0 + a / x0) / 2

Loop While Abs(x - x0) > 0.00001 FSqr1 = x End Function

Private Sub Command1_Click() Dim x!, y!

x = Val(InputBox(\ If x >= 0 Then y = FSqr1(x) Print y End If End Sub

(2)自定义子过程的定义及调用

Sub FSqr2(a As Single, x As Single) Dim x0 As Single x = a Do

x0 = x

x = (x0 + a / x0) / 2

Loop While Abs(x - x0) > 0.00001 End Sub

Private Sub Command2_Click() Dim x!, y!

x = Val(InputBox(\ If x >= 0 Then

Call FSqr2(x, y) Print y End If End Sub

(3)递归函数及调用 [略]

习题七

第1-9题,答案在教材上找;第10,12-14题,略。

11.检测Ctrl和F3同时按下的代码:

Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer)

If Shift = 2 And KeyCode = 114 Then MsgBox \

End Sub

习题八

第1,2,6,7,9题答案可阅读教材找到。

3.写Open语句

(1) Open \ '重写 或 Open \ '添加 (2)Open \

(3)Open \

pf = Format(x * x, \pfg = Format(Sqr(x), \lf = Format(x * x * x, \lfg = Format(x ^ (1 / 3), \

Print \平方为:\平方根为:\立方为:\立方根为:\lfg

End Sub

C.1

Private Sub Form_Click() Dim x!, y!

x = Val(InputBox(\输入x的值\If x < 1000 Then y = x

ElseIf x < 2000 Then y = 0.9 * x

ElseIf x < 3000 Then y = 0.8 * x Else y = 0.7 * x End If Print y End Sub

C.2

Private Sub Form_Click() Dim x!, y!

x = Val(InputBox(\输入上网时间\If x < 10 Then y = 30

ElseIf x < 50 Then y = 30 + 2.5 * (x - 10) Else

y = 30 + 2.5 * 40 + 2 * (x - 50) End If

If y > 150 Then y = 150 End If Print y End Sub

C.3

Private Sub Command1_Click() Dim x!, y!, z!

x = InputBox(\ y = InputBox(\ z = InputBox(\

Print \ x y z\ Print \排序前\ \ \ If x < y Then t = x: x = y: y = t If x < z Then t = x: x = z: z = t If y < z Then t = y: y = z: z = t

Print \排序后\ \ \End Sub

Private Sub Command2_Click() Dim x!, y!, z!

x = InputBox(\ y = InputBox(\ z = InputBox(\

Print \ x y z\ Print \排序前\ \ \ If x < y Then t = x: x = y: y = t If y < z Then t = y: y = z: z = t If x < y Then

t = x: x = y: y = t End If End If

Print \排序后\ \End Sub

C.4

Dim a(3) As Integer

Private Sub Command1_Click() Picture1.Cls For i = 0 To 2

a(i) = Int(Rnd * 100 + 200) Picture1.Print a(i) Next i End Sub

Private Sub Command2_Click() Picture2.Cls Dim z As Integer For i = 0 To 1

If a(i) > a(i + 1) Then z = a(i + 1) a(i + 1) = a(i) a(i) = z

\ End If Next i

Picture2.Print a(0) Picture2.Print a(1) Picture2.Print a(2) End Sub

C.5

Private Sub Text2_LostFocus() Dim m%, n%, y% m = Val(Text1) n = Val(Text2)

If n Mod 2 <> 0 Then

MsgBox (\脚数必定为偶数\ Text2 = \

Text2.SetFocus Else

y = n / 2 - m If y < 0 Then

MsgBox (\脚数必须≥2倍的头数,请重新输入\ Text2 = \

Text2.SetFocus Else

x = n / 2 - m Label2 = y Label3 = m - y End If End If End Sub

C.6

Private Sub Command1_Click() Dim a!, b!, c!, x1!, x2!, de! a = Text1 b = Text2 c = Text3

de = b * b - 4 * a * c t = 2 * a

If de = 0 Then

Text4 = Format(-b / t, \ Text5 = Format(-b / t, \ElseIf de > 0 Then

Text4 = Format((-b + Sqr(de)) / t, \ Text5 = Format((-b - Sqr(de)) / t, \

Else

Text4 = Format(-b / t, \ Text5 = Format(-b / t, \End If End Sub

Private Sub Command2_Click() Text1 = \Text2 = \Text3 = \Text4 = \Text5 = \End Sub

C.7

Private Sub Text3_LostFocus() Select Case Trim(Text3) Case \

Text4 = Val(Text1) + Val(Text2) Case \

Text4 = Val(Text1) - Val(Text2) Case \

Text4 = Val(Text1) * Val(Text2) Case \

If Val(Text2) = 0 Then

MsgBox \分母为零,重新输入\ Text2 = \

Text2.SetFocus Else

Text4 = Val(Text1) / Val(Text2) End If End Select End Sub

C.8

Private Sub Text1_LostFocus() Select Case Trim(Text1) Case 1

Text2 = \ Case 2

Text2 = \ Case 3

Text2 = \ Case 4

Text2 = \

Case 5

Text2 = \ Case 6

Text2 = \ Case 7

Text2 = \ Case Is > 7, Is < 1

MsgBox \数字为1~7,重新输入\ Text1 = \

Text1.SetFocus End Select End Sub 或者

Private Sub Text1_LostFocus() If Text1 > 7 Or Text1 < 1 Then

MsgBox \数字为1~7,重新输入\ Text1 = \

Text1.SetFocus Else

Text2 = Choose(Text1, \\End If End Sub

D.1

Private Sub Form_Click() For i = 1 To 9

Print Tab(10 - i); String(2 * i - 1, Trim(Str(i))) Next i End Sub

D.2

Private Sub Form_Click() For i = 1 To 10 Step 1

Print Tab(i); String((20 - 2 * i), Chr(64 + i)) Next i End Sub

D.3

Private Sub Command1_Click() Dim s!, t!, i& s = 1 t = 1

For i = 1 To 100000

t = t + i s = s + 1 / t

If 1 / t < 0.00001 Then Exit For Next i

Print \结构\项\End Sub

D.4

Private Sub Command1_Click() Dim n&, pi#, i&

n = InputBox(\输入n值\pi = 2

For i = 1 To n

pi = pi * (2 * i) / (2 * i - 1) * (2 * i) / (2 * i + 1) Next i

Print \当n=\时,pi=\End Sub

D.5

Private Sub Form_Click() Dim s!, t!, i!, a%, n% a = Int(Rnd * 9 + 1) n = Int(Rnd * 6 + 5) t = 0: s = 0

Print \ For i = 1 To n t = t * 10 + a s = s + t Print t; Next i Print

Print \End Sub

D.6

Private Sub Command1_Click() Dim s As Integer s = 0

For i = 1 To 9 For j = 0 To 9 For k = 0 To 9

s = i * 100 + j * 10 + k

If s = i ^ 3 + j ^ 3 + k ^ 3 Then Print s

End If Next k Next j Next i End Sub

Private Sub Command3_Click() formd6.Hide main.Show End Sub

D.7

Private Sub Command1_Click() Dim a!, x0!, x1! a = 27 x0 = 2 i = 0 Do

i = i + 1

x1 = 2 * x0 / 3 + a / (3 * x0 * x0)

If Abs(x1 - x0) < 0.00001 Then Exit Do x0 = x1 Loop Print x1, i End Sub

D.8

Private Sub Command1_Click() s = 0 x0 = 0.01

For i = 1 To 30 s = s + x0 x0 = x0 * 2 Next i Print s End Sub

D.9

Private Sub Command4_Click() Picture1.Cls

Picture1.Print \课安排在 \课安排在Picture1.Print \For z = 5 To 6 For x = 1 To z - 2 For Y = x + 1 To z - 1

\课安排在 \ X1 = Choose(Weekday(x), \周一\周二\周三\周四\周五\周六\周日\Y1 = Choose(Weekday(Y), \周一\周二\周三\周四\周五\周六\周日\z1 = Choose(Weekday(z), \周一\周二\周三\周四\周五\周六\周日\Picture1.Print \ \ \Next Y Next x Next z End Sub

E.1

Private Sub Form_Click() Dim a(1 To 10) As Integer For i = 1 To 10

a(i) = Int(Rnd * 71 + 30) Print a(i); \ Next i

Max = a(1) Min = a(1) Avg = a(1) For i = 2 To 10

If a(i) > Max Then Max = a(i) If a(i) < Min Then Min = a(i) Avg = Avg + a(i) Next i

Avg = Avg / 10 Print

Print \ Min=\End Sub

E.2

Private Sub Form_Click() Dim a

a = Array(56, 78, 98, 88, 76, 78) For i = 0 To 5

Print String(a(i) \\ 5, \◆\ Print Next i End Sub

E.3

Dim a%(19)

Private Sub Command1_Click() Picture1.Cls

Avg=\ For i = 0 To 19

a(i) = Int(Rnd * 101) Picture1.Print a(i); \ \

If (i + 1) Mod 4 = 0 Then Picture1.Print Next i End Sub

Private Sub Command2_Click() Picture2.Cls Dim s(5 To 9) For i = 0 To 19 k = a(i) \\ 10 Select Case k Case 0 To 5

s(5) = s(5) + 1

Case 9 To 10 '90~100分的人数 s(9) = s(9) + 1

Case 6 To 8 ' 存放其他三个分数段的下标有规律,根据K获得 s(k) = s(k) + 1 End Select Next i

For i = 5 To 9

If s(i) <> 0 Then Picture2.Print \的人数有 \个\ Next i End Sub

E.4

Private Sub Command1_Click() Picture1.Cls

Dim d%(1 To 10) For i3 = 1 To 10 Randomize

d(i3) = Int(Rnd * 91 + 10) Next i3

For i = 1 To 10 For j = 1 To 10 - i If d(j) < d(j + 1) Then

t = d(j): d(j) = d(j + 1): d(j + 1) = t End If Next j Next i

For i = 1 To 10: Picture1.Print d(i); If i Mod 5 = 0 Then Picture1.Print Next i

End Sub

E.5

Dim a%(3, 3), b%(3, 3) Private Sub Form_Load() For i = 0 To 3 For j = 0 To 3

a(i, j) = Int(Rnd * 36 + 35) b(i, j) = Int(Rnd * 41 + 100) Next j Next i End Sub

Private Sub Command1_Click() Picture1.Cls For i = 0 To 3 For j = 0 To i

Picture1.Print a(i, j); \ \ Next j

Picture1.Print Next i End Sub

Private Sub Command2_Click() Picture2.Cls For i = 0 To 3 For j = i To 3

Picture2.Print Tab(j * 6); b(i, j); Next j

Picture2.Print Next i End Sub

Private Sub Command3_Click() Picture3.Cls sa = 0

For i = 0 To 3 sa = sa + a(i, i) Next i sb = 0

For i = 0 To 3

sb = sb + b(i, 3 - i) Next i

Picture3.Print \数组主对角线元素和为:\ Picture3.Print \数组副对角线元素和为:\End Sub

E.6

Private Sub Form_Click() n = InputBox(\输入n值\ReDim a6%(n + 1, n + 1)

a6(0, 0) = 1: a6(1, 1) = 1: a6(1, 0) = 1 For i = 2 To n + 1 For j = 2 To i

a6(i, j) = a6(i - 1, j - 1) + a6(i - 1, j) Picture1.Print a6(i, j); \ Next j

Picture1.Print Next End Sub

E.7

Private Sub Form_Load() List1.Clear

List1.AddItem \大学计算机基础\ List1.AddItem \程序设计\ List1.AddItem \程序设计\ List1.AddItem \程序设计\ List1.AddItem \多媒体技术与应用\ List1.AddItem \数据库技术与应用\ List1.AddItem \网络技术与应用\ List1.AddItem \硬件技术基础\ List1.AddItem \软件技术技术基础\End Sub

Private Sub List1_Click()

If List2.ListCount >= 5 Then

MsgBox (\超过5门课程,不能再选\ Exit Sub Else

List2.AddItem List1.Text

List1.RemoveItem List1.ListIndex End If End Sub

E.8

Sub Combo1_KeyPress(KeyAscii As Integer) Select Case KeyAscii Case 48 To 57, 13 Case Else

KeyAscii = 0 End Select

If KeyAscii = 13 Then

Combo1.AddItem Combo1.Text Combo1.Text = \ End If End Sub

Private Sub Command1_Click() Dim min%, max%

min = Val(Combo1.List(0)) max = Val(Combo1.List(0)) imin = 0 imax = 0

For i = 1 To Combo1.ListCount - 1 If Val(Combo1.List(i)) > max Then imax = i

max = Combo1.List(i)

ElseIf Val(Combo1.List(i)) < min Then imin = i

min = Combo1.List(i) End If Next i

t = Combo1.List(0)

Combo1.List(0) = Combo1.List(imin) Combo1.List(imin) = t

t = Combo1.List(Combo1.ListCount - 1)

Combo1.List(Combo1.ListCount - 1) = Combo1.List(imax) Combo1.List(imax) = t End Sub

E.9

Private Sub Form_Click()

For i = 0 To Screen.FontCount - 1

If Asc(Left(Screen.Fonts(i), 1)) < 0 Then Picture1.Print Screen.Fonts(i)

Picture2.FontName = Screen.Fonts(i) Picture2.Print \商丘师范学院\ End If Next i End Sub

E.10

Private Type clerk

number As String * 3 name As String * 5 salary As Integer End Type

Dim a(0 To 4) As clerk, n%

Private Sub Command1_Click() If n >= 5 Then

MsgBox (\输入人数超过数组声明的个数\Else

With a(n)

.number = Text1 .name = Text2 .salary = Text3

Picture1.Print a(n).number, a(n).name, a(n).salary Print End With n = n + 1 Text1 = \ Text2 = \ Text3 = \End If End Sub

Private Sub Command2_Click() Dim t As clerk, i%, j% For i = 0 To n - 1 For j = i To n - 1

If a(i).salary < a(j + 1).salary Then t = a(i): a(i) = a(j + 1): a(j + 1) = t End If Next j Next i

Picture1.Cls

Picture1.Print \工号 姓名 工资\For i = 0 To n - 1

Picture1.Print a(i).number, a(i).name, a(i).salary Print Next i End Sub

F.1

Private Sub Form_Click() Dim a(1 To 10), amin, i%

For i = 1 To 10

a(i) = -Int(Rnd * 101 + 300) Print a(i); Next i

Call s(a(), amin) Print

Print \End Sub

Sub s(b(), min) Dim i%

min = b(LBound(b))

For i = LBound(b) + 1 To UBound(b) If b(i) < min Then min = b(i) Next i End Sub

F.2

Private Sub Command1_Click() Dim mm%, nn% mm = Val(Text1) nn = Val(Text2)

Picture1.Print mm; Tab(6); nn; Tab(12); gcd(mm, nn) End Sub

Function gcd%(ByVal m%, ByVal n%) If m < n Then t = m: m = n: n = t r = m Mod n

Do While (r <> 0)

m = n: n = r: r = m Mod n Loop gcd = n End Function

F.3

Dim x!

Private Sub Command1_Click()

Print \调用标准函数Sin的结果\End Sub

Private Sub Command2_Click()

Print \调用自定义函数 MySin的结果\End Sub

Function MySin(x!) As Double Dim i%, t!, s! t = x

s = t i = 1

Do While Abs(t) > 0.00001

t = -1 * t * x * x / ((i + 1) * (i + 2)) s = s + t i = i + 2 Loop

MySin = s End Function

Private Sub Command3_Click()

x = InputBox(\输入要计算正弦函数的角度值x\x = x * 3.14 / 180 End Sub

F.4

Private Sub Text1_KeyPress(KeyAscii As Integer) If KeyAscii = 13 Then

If Not IsNumeric(Text1) Then

MsgBox \输入非数字串,重新输入\ Text1.Text = \ Text1.SetFocus Else

If IsH(Text1) Then

Picture1.Print Text1; \★ \ Else

Picture1.Print Text1 End If Text1 = \ End If End If End Sub

Function IsH(ss As String) As Boolean Dim i%, Ls% IsH = True ss = Trim(ss) Ls = Len(ss)

For i = 1 To Ls \\ 2

If Mid(ss, i, 1) <> Mid(ss, Ls + 1 - i, 1) Then IsH = False Exit Function End If Next i End Function

F.5

Function prime(ByVal m As Integer) As Boolean prime = True Dim i%

For i = 2 To m - 1

If (m Mod i) = 0 Then prime = False: Exit Function '注意冒号和exit的范围 Next i

End Function

Private Sub Command1_Click() n = 0

For i = 6 To 100 Step 2 For j = 3 To i \\ 2 If prime(j) Then If prime(i - j) Then

List1.AddItem i & \n = n + 1 End If End If Next j Next i

Picture1.Print \和100之间共有\对素数和\End Sub

F.6

Dim a%()

Private Sub Form_Click()

Print \以内的完数为:\ For i = 1 To 1000 If IsWs(i) Then Print i; \

For j = 1 To UBound(a) Print \ Next j Print End If Next i End Sub

Function IsWs(m) As Boolean Dim s% s = 0

For i = 1 To m \\ 2

If m Mod i = 0 Then ReDim Preserve a(j) a(j) = i

j = j + 1 s = s + i End If Next i

If m = s Then IsWs = True End Function

F.7

Private Sub DeleStr(s1 As String, ByVal s2 As String) Dim i%

ls2 = Len(s2) i = InStr(s1, s2) Do While i > 0

s1 = Left(s1, i - 1) + Mid(s1, i + ls2) ' 在s1中去除s2子串 i = InStr(s1, s2) Loop End Sub

Private Sub Command1_Click() ' 调用DeleStr子过程 Dim ss1 As String ss1 = Text1

Call DeleStr(ss1, Text2) Text3 = ss1 End Sub

Private Sub Command2_Click()

End Sub

F.8

Private Sub Command1_Click() Dim maxw$

maxlen Text1 & \Text2 = maxw End Sub

Sub maxlen(s$, maxw$) Dim word$ maxw = \

Do While s <> \ i = InStr(s, \

word = Left(s, i - 1)

If Len(word) > Len(maxw) Then maxw = word s = Mid(s, i + 1) Loop

End Sub

G.1

Private Sub Command1_Click() List1.Clear

List1.AddItem Combo1

If Option1 Then List1.AddItem \ If Option2 Then List1.AddItem \ If Option3 Then List1.AddItem \ List1.AddItem Text1

If Check1 Then List1.AddItem \声卡\ If Check2 Then List1.AddItem \ If Check3 Then List1.AddItem \网络适配器\End Sub

Private Sub Text1_LostFocus() st = UCase(Trim(Text1)) le = Len(st)

If Not IsNumeric(Left(st, le - 2)) Or Right(st, 2) <> \ MsgBox \有不合法字符!\ Text1 = \

Text1.SetFocus End If End Sub

G.2

Private Sub Check1_Click()

Picture1.Font.Bold = Not Picture1.Font.Bold End Sub

Private Sub Check2_Click()

Picture1.Font.Italic = Not Picture1.Font.Bold End Sub

Private Sub Command1_Click() Picture1.Cls If Option1 Then

Picture1.Print Sin(Val(Text1)) ElseIf Option2 Then

Picture1.Print Exp(Val(Text1)) ElseIf Option3 Then

Picture1.Print Sqr(Val(Text1)) End If End Sub

Private Sub return_Click(Index As Integer) Form6.Show Unload Form2 End Sub

G.3

Private Sub HScroll1_Change() Text1 = VScroll1.Value Text2 = HScroll1.Value Text3 = HScroll2.Value

Text4 = Format(Val(Text1) * (Text3 / 100) * (Text2 / 12), \ Text5 = Format(Val(Text4) + Val(Text1), \End Sub

Private Sub HScroll2_Change() Text1 = VScroll1.Value Text2 = HScroll1.Value Text3 = HScroll2.Value

Text4 = Format(Val(Text1) * (Text3 / 100) * (Text2 / 12), \ Text5 = Format(Val(Text4) + Val(Text1), \End Sub

Private Sub VScroll1_Change() Text1 = VScroll1.Value Text2 = HScroll1.Value Text3 = HScroll2.Value

Text4 = Format(Val(Text1) * (Text3 / 100) * (Text2 / 12), \ Text5 = Format(Val(Text4) + Val(Text1), \End Sub

G.4

Dim t As Single

Private Sub Command1_Click() t = InputBox(\输入倒计时分钟数\t = t * 60

ProgressBar1.Min = 0 ProgressBar1.Max = t

ProgressBar1.Value = ProgressBar1.Max End Sub

Private Sub Command2_Click() Timer1.Interval = 1000 ProgressBar1.Visible = True Timer1.Enabled = True End Sub

Sub Timer1_Timer() Dim m%, s% t = t - 1

ProgressBar1.Value = t m = t \\ 60 s = t Mod 60

Label1 = m & \分\秒\If t = 0 Then

MsgBox \时间到!\ Timer1.Interval = 0 ProgressBar1.Visible = False End If End Sub

G.5

Private Sub Command1_Click() CommonDialog1.ShowColor

Label1.ForeColor = CommonDialog1.Color End Sub

Private Sub Command2_Click() CommonDialog1.ShowOpen

i = Shell(\End Sub

G.6

rivate Sub bold_Click()

Text1.FontBold = Not Text1.FontBold bold.Checked = Not bold.Checked End Sub

Private Sub del_Click() Text1 = \End Sub

Private Sub end_Click() End End Sub

Private Sub font12_Click() Text1.FontSize = 12 End Sub

Private Sub font16_Click() Text1.FontSize = 16 End Sub

Private Sub Form_Load() bold.Checked = False italic.Checked = False End Sub

Private Sub italic_Click()

Text1.FontItalic = Not Text1.FontItalic italic.Checked = Not italic.Checked End Sub

Private Sub Text1_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single) If Button = 2 Then PopupMenu menu2 End Sub

G.7

Private Sub Command1_Click() CommonDialog1.ShowColor

Label1.ForeColor = CommonDialog1.Color End Sub

Private Sub Command2_Click() CommonDialog1.ShowOpen

i = Shell(\End Sub

Private Sub return_Click(Index As Integer) Form6.Show Unload Form5 End Sub

G.8 G.9

Private Sub 结束_Click() End End Sub

Private Sub 删除最大值_Click() max = List1.List(0)

For i = 1 To List1.ListCount - 1

If max < List1.List(i) Then max = List1.List(i): j = i Next i

List1.RemoveItem j End Sub

Private Sub 删除最小值_Click() min = List1.List(0)

For i = 1 To List1.ListCount - 1

If min > List1.List(i) Then min = List1.List(i): j = i Next i

List1.RemoveItem j End Sub

Private Sub 随机产生_Click()

Randomize For i = 0 To 9

List1.List(i) = Int(Rnd * 30 + 70) Next i End Sub

Private Sub 添加数据_Click() List1.AddItem Int(Rnd * 30 + 70) End Sub

Private Sub 统计_Click()

Dim max%, min%, ave!, m%, n% max = List1.List(0) min = List1.List(0) ave = List1.List(0) m = 0 n = 0

For i = 1 To List1.ListCount - 1

If max < List1.List(i) Then max = List1.List(i): m = i If min > List1.List(i) Then min = List1.List(i): n = i ave = ave + List1.List(i) Next i

Form2.Text1 = List1.List(n) Form2.Text2 = List1.List(m)

Form2.Text3 = Format(ave / List1.ListCount, \Form2.Show

End Sub

G.10

Private Sub experimentG2_Click() Form2.Show End Sub

Private Sub experimentG3_Click() Form3.Show End Sub

Private Sub experimentG4_Click() Form4.Show End Sub

Private Sub experimentG5_Click() Form5.Show

End Sub

Private Sub font_12_Click() Text1.FontSize = 12 End Sub

Private Sub font_16_Click() Text1.FontSize = 16 End Sub

Private Sub rnd10_Click() Randomize For i = 0 To 9

List1.List(i) = Int(Rnd * 30 + 70) Next i End Sub

Private Sub stat_Click()

Dim max%, min%, ave!, m%, n% max = List1.List(0) min = List1.List(0) ave = List1.List(0) m = 0 n = 0

For i = 1 To List1.ListCount - 1

If max < List1.List(i) Then max = List1.List(i): m = i If min > List1.List(i) Then min = List1.List(i): n = i ave = ave + List1.List(i) Next i

stat2.Text1 = List1.List(n) stat2.Text2 = List1.List(m)

stat2.Text3 = Format(ave / List1.ListCount, \stat2.Show End Sub

Private Sub Text1_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single) If Button = 2 Then PopupMenu caidan2, vbPopupMenuCenterAlign End Sub

Private Sub xie_Click()

Text1.Font.Italic = Not Text1.Font.Bold End Sub

H.1

Private Sub Command1_Click() Open \Print #1, \王海涛\Print #1, \周文英\Print #1, \陈建东\Open \Write #2, \王海涛\Write #2, \周文英\Write #2, \陈建东\Close

i1 = Shell(\i2 = Shell(\End Sub

Private Sub Command2_Click()

Dim no As String, name As String, s As Integer Open \Do While Not EOF(1) Line Input #1, linedata List1.AddItem linedata Loop

Open \Do While Not EOF(2) Input #2, no, name, s

List2.AddItem no & name & s Loop Close End Sub

H.2

Private Sub Command1_Click() Dim fib%(0 To 9), i%

Open \For i = 0 To 9

If i = 0 Or i = 1 Then fib(i) = i Else

fib(i) = fib(i - 1) + fib(i - 2) End If

Print #1, \Next i Close #1

i = Shell(\End Sub

Private Sub Command2_Click() Dim st$, n%, sum%

Open \Do While Not EOF(1) Input #1, st, n sum = sum + n

List1.AddItem st & \Loop Close #1

List1.AddItem \合计:\List1.AddItem \平均:\End Sub

H.3

H.4

Private Type studtype

no As String * 4 name As String * 6 mark As Single End Type

Dim student As studtype, stud(1 To 5) As studtype, t As studtype

Private Sub Command1_Click()

Open \With student .no = \

.name = \星期一\ .mark = 66 End With

Put #1, 1, student With student .no = \

.name = \星期二\ .mark = 99 End With

Put #1, 2, student With student .no = \

.name = \星期三\ .mark = 88 End With

Put #1, 3, student With student .no = \

.name = \星期四\ .mark = 55 End With

Put #1, 4, student With student .no = \

.name = \星期五\ .mark = 77 End With

Put #1, 5, student Close #1 End Sub

Private Sub Command2_Click()

Open \For i = 1 To 5 Get #1, i, student

Print student.no, student.name, student.mark stud(i) = student Next i Close #1 For i = 1 To 5 For j = i + 1 To 5

If stud(i).mark > stud(j).mark Then t = stud(i): stud(i) = stud(j): stud(j) = t Next Next i

Open \For i = 1 To 5 Put #2, i, stud(i) Next i Close #1 End Sub

Private Sub Command3_Click()

Open \For i = 1 To 5 Get #1, i, stud(i)

Print stud(i).no; stud(i).name; stud(i).mark Next i Close #1

End Sub

H.5

Private Type studtype no As Integer

name As String * 20 sex As String * 1 mark As Single End Type

Dim std As studtype Dim record As Integer

Private Sub Command1_Click() With std

.no = Val(Text1.Text) .name = Text2.Text

.sex = IIf(Option1.Value, \.mark = Val(Text3.Text) End With

Open \record = LOF(1) / Len(std) + 1 Label1.Caption = record Put #1, record, std Close #1 End Sub

Private Sub Command2_Click()

Open \record = Val(Text4.Text) Get #1, record, std Text1.Text = std.no Text2.Text = std.name If std.sex = \Option1.Value = True Else

Option2.Value = True End If

Text3.Text = std.mark

record = LOF(1) / Len(std) Close #1 End Sub

Private Sub Command3_Click()

With std

.no = Val(Text1.Text) .name = Text2.Text

.sex = IIf(Option1.Value, \.mark = Val(Text3.Text) End With

Open \record = Val(Text4.Text) Put #1, record, std Close #1 End Sub

Private Sub Command4_Click()

Open \record = 1

Get #1, record, std Text1.Text = std.no Text2.Text = std.name If std.sex = \Option1.Value = True Else

Option2.Value = True End If

Text3.Text = std.mark

record = LOF(1) / Len(std) Close #1

Text4.Text = 1 End Sub

Private Sub Command5_Click()

Open \record = Val(Text4.Text) - 1 If Val(Text4.Text) <= 1 Then

MsgBox \超出记录范围\警告\Else

Get #1, record, std Text1.Text = std.no Text2.Text = std.name If std.sex = \Option1.Value = True Else

Option2.Value = True End If

Text3.Text = std.mark

record = LOF(1) / Len(std) Close #1

Text4.Text = Val(Text4.Text) - 1 End If End Sub

Private Sub Command6_Click()

Open \record = Val(Text4.Text) + 1

If record > Val(Label1.Caption) Then

MsgBox \超出记录范围\警告\Else

Get #1, record, std Text1.Text = std.no Text2.Text = std.name If std.sex = \Option1.Value = True Else

Option2.Value = True End If

Text3.Text = std.mark

record = LOF(1) / Len(std) Close #1

Text4.Text = Val(Text4.Text) + 1 End If End Sub

Private Sub Command7_Click()

Open \record = Val(Label1.Caption) Get #1, record, std Text1.Text = std.no Text2.Text = std.name If std.sex = \Option1.Value = True Else

Option2.Value = True End If

Text3.Text = std.mark

record = LOF(1) / Len(std) Close #1

Text4.Text = record End Sub

本文来源:https://www.bwwdw.com/article/ic5p.html

Top