某移数字游戏的规则如下:有一个如图a所示的包含9个圆圈的数阵.将1~8这8个数字随机地填写到该数阵的外层圆圈中,只剩下中间的一个空圆圈.规定每个数字只能按照数阵中的直线从一个圆圈移动到另一个空的圆圈中.通过若干步的移动,要求将该数阵中的数字移动成为如图b所示的状态.
小张编写了一个VB程序来解这个游戏,功能如下:点击“初始化”按钮Command1初始化游戏,程序随机地将1~8这8个整数填入到数阵的外层圆圈中,同时将该状态下的数阵显示在列表框List1中.点击“开始”按钮Command2,程序开始移数字,并将移动过程中的每一步输出在列表框List2中,最后统计总移动步数到标签Label1中.为了清楚地描述输出数字在数阵中的每一步移动步骤,小张给数阵中的每一个圆圈都进行了编号,具体编号方法如图c所示,因此1号圈中的数字移动到2号圈可以表示为“1#-->2#”.程序运行界面如图d所示.

实现上述功能的VB代码如下.
(1)请在横线处填入合适代码
Dim a(1To 8)As String
Private Sub Command1_Click ( )
Dim temp As Integer,i As Integer,j As Integer
Dim flag(1To 8)As Boolean
For i=1To 8
flag(i)=Falseflag(i)=False
Next i
Randomize
For i=1To 8
temp=Int(Rnd ( )*8+1)'生成1~8之间的随机整数
Do While flag(temp)
temp=Int(Rnd ( )*8+1)'生成1~8之间的随机整数
Loop
a(i)=temp
flag(temp)=True
Next i
List1.Clear
List1.AddItem“初始状态:“
PrintCircle
End Sub
Private Sub Command2_Click ( )
Dim i As Integer,j As Integer,temp As String,n As Integer,moveStep As String
moveStep=““
List2.Clear
n=0
For i=1To 7'使用冒泡排序对圆圈中的数字进行移动
For j=1To ②②
If a(j)>=a(j+1)Then
temp=a(j):a(j)=a(j+1):a(j+1)=temp
moveStep=Str(j) &“#-->0#“
moveStep=moveStep &““& Str(j+1)&“#-->“& Str(j) &“#“moveStep=moveStep &““&“0#-->“& Str(j+1)&“#“
List2.AddItem moveStep
n=n+1
End If
Next j
Next i
List1.AddItem“移动数字后:“
PrintCircle
Label1.Caption=“总移动步数:“& ③③
End Sub
'在列表框List1中输出当前的数阵状态
Function PrintCircle ( )
List1.AddItem“-------------------------“
List1.AddItem“[“& a(1)&“]-[“& a(2)&“]-[“& a(3)&“]“
List1.AddItem“|\|/|“
List1.AddItem“[“& a(8)&“]-[“&““&“]-[“& a(4)&“]“
List1.AddItem“|/|\|“
List1.AddItem“[“& a(7)&“]-[“& a(6)&“]-[“& a(5)&“]“
List1.AddItem“-------------------------“
End Function
(2)分析代码和游戏规则,事件处理过程“Command2_Click”中的冒泡排序 不能不能(填:能/不能)改为使用选择排序.
【考点】对象的属性、方法和事件;编辑事件处理过程的代码.
【答案】flag(i)=False;②;③;不能
【解答】
【点评】
声明:本试题解析著作权属菁优网所有,未经书面同意,不得复制发布。
发布:2024/6/27 10:35:59组卷:7引用:1难度:0.3
相似题
-
1.运行列表框对象语句:List1.AddItem=“同学们好!“,会显示:同学们好!;
发布:2025/1/2 11:30:1组卷:6引用:6难度:0.9 -
2.小张设计了一个“加减运算练习”VB程序.界面如下图所示.单击“出题”Command1按钮显示两个运算数和运算符号,并计数.在文本框Text1中输入计算结果后单击“判断”按钮Command2,如果计算结果正确,则得分加10分,直至完成10题测试.VB程序如下,但加下横线处代码有错,请改正.
Dim n,s As Integer'n为试题计数器,s为得分
Dim a,b As Integer'a,b 为两个运算数
Dim c As String'c为运算符:“+“表示加法,“-“表示减法
Private Sub Form_Load( )n=0:
s=0
End Sub
Private Sub Command1_Click( )‘出题按钮
Randomize
n=n+1
If n<11Then
Label1.Caption=“No:“+Str(n)
a=Int(Rnd*100)'a,b为运算数,且要求a不小于b
b=Int(Rnd*100)
If a>bThen t=a:a=b:b=t'(1)
If Rnd>0.5Then c=“+“Else b=“-“'(2)
Label5.Caption=Str(a)+c+Str(b)+“=“
Text1.Text=““
Else
Command1.Caption=“完成测试“
End If
End Sub
Private Sub Command2_Click( )‘判断按钮
If c=“+“Then
If a+b=Val(Text1.Text) Then s=s+10
Else
If a+b=Val(Text1.Text)Then s=s+10'(3)
End If
Label3.Caption=“得分:“+Str(s)
End Sub.发布:2025/1/2 9:30:2组卷:6引用:2难度:0.9 -
3.某智能农场启用了根据土壤湿度自动控制喷淋装置进行浇水的信息系统,每隔一段时间,系统自动检测土壤湿度,当土壤湿度低于某个阈值时将自动浇水。小李为统计出某段时间内(不超过100个时间单位)系统自动控制浇水的次数和该时间段内前后两次启动自动浇水系统的最大时间间隔单位,小李进行了数据分析,他认为如果某单位时间的土壤湿度比前一单位时间的土壤湿度高并且本单位时间内没有下雨,则认为启用了浇水系统。由此他编写了一个VB程序实现该功能:在文本框Text1中输入某段时间内的湿度值,在文本框Text2中输入该段时间内对应的天气情况,单击命令按钮Command1,在文本框Text3中显示系统自动浇水次数,Text4中显示前后两次自动浇水系统启用的最大时间间隔单位。
(1)在Private Sub Command1_Click( )中,Command1、Click分别表示
(2)实现上述功能的VB程序如下,请在画线处填入合适的代码。
(3)程序中加框处代码有错,请改正。发布:2025/1/2 11:0:1组卷:0引用:1难度:0.3