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

【加試題】課堂隨機提問產(chǎn)生器.小葉同學(xué)發(fā)現(xiàn)老師在上課提問時喜歡叫座位靠前的同學(xué)回答問題,有時一節(jié)課會重復(fù)叫到某一位同學(xué)多次,為了實現(xiàn)每個同學(xué)被叫到回答問題的幾率均等,且在一節(jié)課老師提問次數(shù)少于班級總?cè)藬?shù)時,被叫到過回答問題的同學(xué)本節(jié)課不再被叫到,小葉同學(xué)用VB設(shè)計了一個課堂隨機提問產(chǎn)生器,功能如下:運行程序時,在列表框List1中顯示班級學(xué)生數(shù)據(jù),單擊“隨機叫號”按鈕Command1,在文本框Text1、Text2中分別顯示學(xué)生學(xué)號和姓名,其應(yīng)用程序界面如圖所示.
菁優(yōu)網(wǎng)
班級學(xué)生的具體數(shù)據(jù)信息存放在數(shù)據(jù)庫文件“student.accdb”的“stu”表中,班級學(xué)生數(shù)不超過60人.
實現(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)生的隨機序號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對象實例conn
Dim rs As New ADODB.Recordset'定義Recordset對象實例rs
conn.ConnectionString=“provider=Microsoft.ACE.OLEDB.12.0;data source=”& App.Path &“\student.accdb”'設(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)請在橫線處填上合適的代碼.
程序中①橫線處應(yīng)填入
flag(num)或flag(num)=true
flag(num)或flag(num)=true

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

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

【答案】①flag(num);②conn.Close;flag(num)或flag(num)=true;conn.Close;當班級人數(shù)少于60人時,如果用60來替換,會出現(xiàn)隨機號大于班級人數(shù)的現(xiàn)象,從而導(dǎo)致沒有學(xué)生與之對應(yīng);.
【解答】
【點評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:17引用:1難度:0.1
相似題
  • 1.如圖VB應(yīng)用程序界面所示,下列關(guān)于類與對象的說法正確的是(  )
    菁優(yōu)網(wǎng)

    發(fā)布:2024/11/3 16:0:2組卷:5引用:2難度:0.7
  • 2.編寫VB程序,實現(xiàn)如下功能:對于任意一個正整數(shù),如果是奇數(shù),則乘3加1,如果是偶數(shù),則除以2,得到的結(jié)果再按照上述規(guī)則重復(fù)處理,最終總能夠得到1.如,假定初始整數(shù)為5,計算過程分別為16、8、4,、2、1.
    程序要求輸入一個整數(shù)到Text1,單擊命令按鈕Command1,將經(jīng)過處理得到1的過程輸出到List1上面,運行效果如圖2所示.
    菁優(yōu)網(wǎng)
    (1)如果將窗體左上角標題“Form1”改為“角谷猜想”,可將Form1的
     
    屬性的屬性值改為“角谷猜想”.
    (2)為實現(xiàn)上述功能,請在橫線處填入合適代碼.
    Private Sub Command1_Click ( ?。?br />Dim x As Long
    x=Val(Text1.Text)'將text1中的內(nèi)容賦值給x
    Do While x<>1
    If
     
    Then'x為奇數(shù)的情況
    x=x*3+1
    Else'x為偶數(shù)的情況
    x=
     

    List1.AddItem“x=“& Str(x)'將x的變化添加到list1上
    Loop
    End Sub
    橫線處①應(yīng)填入
     
    ,劃線②應(yīng)填入
     

    (3)運行程序是,發(fā)下如2圖所示錯誤,原因可能是
     
    (選填:程序缺少Do/程序缺少End If).

    發(fā)布:2024/10/26 17:0:2組卷:7引用:1難度:0.1
  • 3.日期判斷:從文本框Text1輸入一個8位數(shù)字表示的日期,其中第1到4位表示年(第1位確定不為零),第5到6位表示月,第7到8位表示日.單擊“判斷”按鈕,判斷該日期是否合法,將結(jié)果依次輸出到列表框List1.程序界面如下圖所示:
    提示:年份值符合下列兩種情況之一的是閏年.
    1.年份是4的倍數(shù),但不是100的倍數(shù);
    2.年份是400的倍數(shù).
    菁優(yōu)網(wǎng)
    (1)觀察程序代碼,可知“判斷”按鈕的對象名為
     
    .(單選,填字母:A.Text1/B.List1/C.Command1/D.Judge/E.判斷)
    (2)為實現(xiàn)上述功能,請在橫線處填入合適的代碼.
    Private Sub Judge_Click(  )Dim riqi As String,st As String
    Dim year As Integer,month As Integer,day As Integer
    Dim rn As Boolean,hefa As Boolean
    riqi=Text1.Text
    year=Val(Mid(riqi,1,4))
    month=Val(Mid(riqi,5,2))
    day=①
     
    ‘第①處
    st=Str(year)+“年“+Str(month)+“月“+Str(day)+“日“
    rn=False‘用于判斷是否為閏年
    If②
     
     Then rn=True‘第②處
    If year Mod 4=0And year Mod 100<>0Then rn=True
    hefa=True‘用于判斷是否為合法日期
    If month=0Or month>12Then hefa=False
    If day=0Then hefa=False
    If (month=1Or month=3Or month=5Or month=7Or’與下一行語句同行
    month=8Or month=10Or month=12)And day>31Then hefa=False
    If (month=4Or month=6Or month=9Or month=11)’與下一行語句同行
    And day>30Then hefa=False
    If  ③
     
      Then hefa=False
    ’第③處,判斷閏年2月的天數(shù)是否合法
    If month=2And Rn=False And day>28Then hefa=False
    If hefa=True Then st=st+“合法日期“Else st=st+“非法日期“
    List1.AddItem st
    End Sub.

    發(fā)布:2024/10/31 8:0:1組卷:8引用:0難度:0.1
小程序二維碼
把好題分享給你的好友吧~~
APP開發(fā)者:深圳市菁優(yōu)智慧教育股份有限公司 | 應(yīng)用名稱:菁優(yōu)網(wǎng) | 應(yīng)用版本:4.8.2  |  隱私協(xié)議      第三方SDK     用戶服務(wù)條款廣播電視節(jié)目制作經(jīng)營許可證出版物經(jīng)營許可證網(wǎng)站地圖本網(wǎng)部分資源來源于會員上傳,除本網(wǎng)組織的資源外,版權(quán)歸原作者所有,如有侵犯版權(quán),請立刻和本網(wǎng)聯(lián)系并提供證據(jù),本網(wǎng)將在三個工作日內(nèi)改正