試卷征集
          加入會員
          操作視頻

          用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
          APP開發者:深圳市菁優智慧教育股份有限公司| 應用名稱:菁優網 | 應用版本:5.0.7 |隱私協議|第三方SDK|用戶服務條款
          本網部分資源來源于會員上傳,除本網組織的資源外,版權歸原作者所有,如有侵犯版權,請立刻和本網聯系并提供證據,本網將在三個工作日內改正