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

【加試題】課堂隨機(jī)提問產(chǎn)生器.小葉同學(xué)發(fā)現(xiàn)老師在上課提問時(shí)喜歡叫座位靠前的同學(xué)回答問題,有時(shí)一節(jié)課會重復(fù)叫到某一位同學(xué)多次,為了實(shí)現(xiàn)每個同學(xué)被叫到回答問題的幾率均等,且在一節(jié)課老師提問次數(shù)少于班級總?cè)藬?shù)時(shí),被叫到過回答問題的同學(xué)本節(jié)課不再被叫到,小葉同學(xué)用VB設(shè)計(jì)了一個課堂隨機(jī)提問產(chǎn)生器,功能如下:運(yùn)行程序時(shí),在列表框List1中顯示班級學(xué)生數(shù)據(jù),單擊“隨機(jī)叫號”按鈕Command1,在文本框Text1、Text2中分別顯示學(xué)生學(xué)號和姓名,其應(yīng)用程序界面如圖所示.

班級學(xué)生的具體數(shù)據(jù)信息存放在數(shù)據(jù)庫文件“student.jye.ai”的“stu”表中,班級學(xué)生數(shù)不超過60人.
實(shí)現(xiàn)上述功能的VB程序代碼如下:
Dim xh(1To 60)As Integer'定義存儲學(xué)生學(xué)號的數(shù)組xh
Dim Xm(1To 60)As String'定義存儲學(xué)生學(xué)號姓名的數(shù)組xm
Dim flag(1To 60)As Boolean'定義存儲學(xué)生是否被提問過
flag
Dim n As Integer'定義存儲班級學(xué)生總數(shù)的變量n
Dim num As Integer'定義存儲產(chǎn)生的隨機(jī)序號num
Dim total As Integer
Private Sub Command1_Click(  )
Randomize
num=Int(Rnd*n)+1
Do While
①flag(num)
①flag(num)

num=Int(Rnd*n)+1
Loop
flag(num)=True
total=total+1
Text1.Text=xh(num)
Text2.Text=xm(num)
If total>=n Then
For i=1To n
flag(i)=False
n=0
Next i
End If
End Sub
Private Sub Form_Load( ?。?br />Dim con As New ADODB.Connection'定義Connection對象實(shí)例conn
Dim rs As New ADODB.Recordset'定義Recordset對象實(shí)例rs
conn.ConnectionString=“provider=Microsoft.ACE.OLEDB.12.0;data source=”& App.Path &“\student.jye.ai”'設(shè)置conn的數(shù)據(jù)庫鏈接字符串
conn.Open'找開數(shù)據(jù)鏈接
rs.ActiveConnection=conn'設(shè)置rs的ActiveConnection屬性,關(guān)聯(lián)conn
rs.Open“SELECT*FROM stu”'打開記錄集,獲取數(shù)據(jù)
n=0
Do While Not rs.EOF
n=n+1
xh(n)=rs.Fields(0)'學(xué)生學(xué)號字段的序號為0
xm(n)=rs.Fields(1)'學(xué)生姓名字段的序號為1
List1.AddItem xh(n)&“--”& xm(n)
rs.MoveNext
Loop rs.Close
②conn.Close
②conn.Close

For i=1To n'初始化flag數(shù)組的值
flag(i)=Flase
Next i
total=0
End Sub
(1)請?jiān)跈M線處填上合適的代碼.
程序中①橫線處應(yīng)填入
flag(num)或flag(num)=true
flag(num)或flag(num)=true

程序中②橫線處應(yīng)填入
conn.Close
conn.Close

(2)如將產(chǎn)生隨機(jī)數(shù)的程序代碼“Int(Rnd*n)+1”中的變量n直接用xh數(shù)組下標(biāo)60來替換,會出現(xiàn)沒有學(xué)生回答問題的現(xiàn)象,請簡要說明原因:
當(dāng)班級人數(shù)少于60人時(shí),如果用60來替換,會出現(xiàn)隨機(jī)號大于班級人數(shù)的現(xiàn)象,從而導(dǎo)致沒有學(xué)生與之對應(yīng)
當(dāng)班級人數(shù)少于60人時(shí),如果用60來替換,會出現(xiàn)隨機(jī)號大于班級人數(shù)的現(xiàn)象,從而導(dǎo)致沒有學(xué)生與之對應(yīng)

【答案】①flag(num);②conn.Close;flag(num)或flag(num)=true;conn.Close;當(dāng)班級人數(shù)少于60人時(shí),如果用60來替換,會出現(xiàn)隨機(jī)號大于班級人數(shù)的現(xiàn)象,從而導(dǎo)致沒有學(xué)生與之對應(yīng);.
【解答】
【點(diǎn)評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:17引用:1難度:0.1
相似題
  • 1.運(yùn)行列表框?qū)ο笳Z句:List1.AddItem=“同學(xué)們好!“,會顯示:同學(xué)們好?。?!--BA-->
     
    (判斷對錯)

    發(fā)布:2025/1/2 11:30:1組卷:6引用:6難度:0.9
  • 2.小張?jiān)O(shè)計(jì)了一個“加減運(yùn)算練習(xí)”VB程序.界面如下圖所示.單擊“出題”Command1按鈕顯示兩個運(yùn)算數(shù)和運(yùn)算符號,并計(jì)數(shù).在文本框Text1中輸入計(jì)算結(jié)果后單擊“判斷”按鈕Command2,如果計(jì)算結(jié)果正確,則得分加10分,直至完成10題測試.VB程序如下,但加下橫線處代碼有錯,請改正.
    Dim n,s As Integer'n為試題計(jì)數(shù)器,s為得分
    Dim a,b As Integer'a,b 為兩個運(yùn)算數(shù)
    Dim c As String'c為運(yùn)算符:“+“表示加法,“-“表示減法
    Private Sub Form_Load( ?。﹏=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為運(yùn)算數(shù),且要求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( ?。袛喟粹o
    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.

    發(fā)布:2025/1/2 9:30:2組卷:6引用:2難度:0.9
  • 3.某智能農(nóng)場啟用了根據(jù)土壤濕度自動控制噴淋裝置進(jìn)行澆水的信息系統(tǒng),每隔一段時(shí)間,系統(tǒng)自動檢測土壤濕度,當(dāng)土壤濕度低于某個閾值時(shí)將自動澆水。小李為統(tǒng)計(jì)出某段時(shí)間內(nèi)(不超過100個時(shí)間單位)系統(tǒng)自動控制澆水的次數(shù)和該時(shí)間段內(nèi)前后兩次啟動自動澆水系統(tǒng)的最大時(shí)間間隔單位,小李進(jìn)行了數(shù)據(jù)分析,他認(rèn)為如果某單位時(shí)間的土壤濕度比前一單位時(shí)間的土壤濕度高并且本單位時(shí)間內(nèi)沒有下雨,則認(rèn)為啟用了澆水系統(tǒng)。由此他編寫了一個VB程序?qū)崿F(xiàn)該功能:在文本框Text1中輸入某段時(shí)間內(nèi)的濕度值,在文本框Text2中輸入該段時(shí)間內(nèi)對應(yīng)的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動澆水次數(shù),Text4中顯示前后兩次自動澆水系統(tǒng)啟用的最大時(shí)間間隔單位。

    (1)在Private Sub Command1_Click( ?。┲校珻ommand1、Click分別表示
     
    (單選,填字母:A.對象名、屬性名/B.對象名、事件名/C.類名、方法名)。
    (2)實(shí)現(xiàn)上述功能的VB程序如下,請?jiān)诋嬀€處填入合適的代碼。
    (3)程序中加框處代碼有錯,請改正。

    發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3
APP開發(fā)者:深圳市菁優(yōu)智慧教育股份有限公司| 應(yīng)用名稱:菁優(yōu)網(wǎng) | 應(yīng)用版本:5.0.7 |隱私協(xié)議|第三方SDK|用戶服務(wù)條款
本網(wǎng)部分資源來源于會員上傳,除本網(wǎng)組織的資源外,版權(quán)歸原作者所有,如有侵犯版權(quán),請立刻和本網(wǎng)聯(lián)系并提供證據(jù),本網(wǎng)將在三個工作日內(nèi)改正