试卷征集
加入会员
操作视频

用VB编写一个模拟在900个观众中产生10个中奖号码的程序,每位观众用三位数字进行编号,要求产生的10个号码不能重复,并且升序排列输出.
①检查产生号码是否重复:把产生的中奖号码放在数组a中,新生的号码与已经产生的号码进行一一对比,如果找到相等的数,则重新产生新号码.
②找到新产生号码存放的数组下标:从下标为1的数组元素开始,新号码(第i个号码)分别与他们进行一一比较,找到第一个比新号码大的数,该数所在的下标就是新号码应存放的下标.如果在已经产生的数中没有找到比新号码大的数,则新号码应存放在下标为i的数组元素中.下表以产生第5个号码为例,如果产生的号码是150,第一个比他大的数是a(2),下标为2的数组元素应存放新号码;如果产生的号码是300,则新号码应存放在下标为5的数组元素中.
数组元素 a(1) a(2) a(3) a(4)
数组元素的值 120 188 211 278
③移动数组元素到新的位置:如果在已经产生的号码中找到比新号码大的数,从上一个产生的号码开始,到新号码应存放的数组元素,依次把他们向后面移动.以②中产生150为例,从a(4)开始,让a(5)的值等于a(4),a(4)的值等于a(3),依此类推,直到新号码应存放的数组元素a(2)为止.
④将新产生的号码放在相应的数组元素中.
程序运行的界面如图所示,实现上述功能的VB程序代码如下:
Dim a(10)As Single
Private Sub Command1_Click (  )
Dim i As Integer,j As Integer
Dim temp As Single,k As Integer‘temp产生随机数,k随机数存放数组元素的下标
Randomize
a(1)=Int(Rnd (  )*900+100)
For i=2To 10
temp=Int(Rnd (  )*900+100)
If  seach(temp,i-1)=True  Then
i=i-1
Else

For j=-1To k Step-1
a(j+1)=a(j)
Next j
a(k)=temp
a(k)=temp

End If
Next i
List1.Clear
For i=1To 10
List1.AddItem Str(a(i))
Next i
End Sub
‘函数实现在数组a中,从下标为1的数组元素到下标为t数组元素,查找有无pp的数值
Function seach(pp As Single,t As Integer) As Boolean
Dim i As Integer
seach=False
For i=1To t
If
pp=a(i)
pp=a(i)
 Then seach=True:Exit For
Next i
End Function
(1)程序中横线处①应填入
a(k)=temp
a(k)=temp
程序中横线处②应填入
pp=a(i)
pp=a(i)

(2)加框处的程序段实现的功能是
找到新产生号码存放的数组下标
找到新产生号码存放的数组下标

【答案】a(k)=temp;pp=a(i);a(k)=temp;pp=a(i);找到新产生号码存放的数组下标
【解答】
【点评】
声明:本试题解析著作权属菁优网所有,未经书面同意,不得复制发布。
发布:2024/4/20 14:35:0组卷:0引用: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分别表示
     
    (单选,填字母:A.对象名、属性名/B.对象名、事件名/C.类名、方法名)。
    (2)实现上述功能的VB程序如下,请在画线处填入合适的代码。
    (3)程序中加框处代码有错,请改正。

    发布:2025/1/2 11:0:1组卷:0引用:1难度:0.3
深圳市菁优智慧教育股份有限公司
粤ICP备10006842号公网安备44030502001846号
©2010-2025 jyeoo.com 版权所有
APP开发者:深圳市菁优智慧教育股份有限公司| 应用名称:菁优网 | 应用版本:5.0.7 |隐私协议|第三方SDK|用户服务条款
广播电视节目制作经营许可证|出版物经营许可证|网站地图
本网部分资源来源于会员上传,除本网组织的资源外,版权归原作者所有,如有侵犯版权,请立刻和本网联系并提供证据,本网将在三个工作日内改正