在數(shù)據庫的兩張數(shù)據表中有各有一批學生的考試成績,小吳要將兩張表中的數(shù)據讀取并按成績從高到低排列輸出.成績相同時,第一批學生優(yōu)先輸出.小吳編寫了一個VB程序,程序運行時,將相關信息分別讀入數(shù)組cj和xm的前后兩段,單擊按鈕 Command1 后,在列表框List1中輸出運行結果.實現(xiàn)上述功能的 VB 代碼如下,但加框處代碼有錯,請改正:
Dim xm(1to 1000)as string'存儲學生姓名
Dim cj(1to 1000)as integer'存儲學生成績
Dim rs1 as integer'第一批學生人數(shù)
Dim rs2 as integer'第二批學生人數(shù)
Private Sub Form_Load'該處具體代碼省略
'第1步:從數(shù)據庫讀取第1批學生的人數(shù)rs1,按成績從高到低的順序將成績存入cj(1)、'cj(2)…cj(rs1)中,姓名存入xm(1)、xm(2)…xm(rs1)中
'第2步:從數(shù)據庫讀取第2批學生的人數(shù)rs2,按成績從高到低的順序將成績存入'cj(rs1+1)、cj(rs1+2)…cj(rs1+rs2)中,姓名存入xm(rs1+1)、xm(rs1+2)…xm(rs1+rs2)中
End Sub
Private Sub Command1_Click
i=1'i表示第一批中,尚未輸出的學生中成績最高學生的序號
j=rs1+1'j表示第二批中,尚未輸出的學生中成績最高學生的序號
‘以下程序開始按成績高低逐個輸出,每次輸出前后兩段中,尚未處理的學生中成績最高的
n=1 |
n=0
n=0
‘(1)Do While i<=rs1And j<=rs1+rs2‘兩段都有未輸出的情況,輸出兩段中最大值
n=n+1
If cj(i)>=cj(j) Then
k=i:i=i+1
Else
k=j:j=j+1
End If
List1.AddItem (“第“+Str(n)+“名“+xm(k)+“成績:“+Str(cj(k)))
Loop
Do While i<=rs1‘剩下第一段還有未輸出的,逐個輸出
n=n+1
List1.AddItem (“第“+Str(n)+“名“+xm(i)+“成績:“+Str(cj(i)))
i=i+1
Loop
Do While
j<=rs2 |
j<=rs1+rs2
j<=rs1+rs2
‘(2)若第二段還有未輸出的,逐個輸出n=n+1
List1.AddItem (“第“+Str(n)+“名“+xm(j)+“成績:“+Str(cj(j)))
j=j+1
Loop
End Sub.
【考點】對象的屬性、方法和事件;編輯事件處理過程的代碼.
【答案】n=0;j<=rs1+rs2
【解答】
【點評】
聲明:本試題解析著作權屬菁優(yōu)網所有,未經書面同意,不得復制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:8引用:1難度:0.3
相似題
-
1.運行列表框對象語句:List1.AddItem=“同學們好!“,會顯示:同學們好??;
發(fā)布:2025/1/2 11:30:1組卷:6引用:6難度:0.9 -
2.小張設計了一個“加減運算練習”VB程序.界面如下圖所示.單擊“出題”Command1按鈕顯示兩個運算數(shù)和運算符號,并計數(shù).在文本框Text1中輸入計算結果后單擊“判斷”按鈕Command2,如果計算結果正確,則得分加10分,直至完成10題測試.VB程序如下,但加下橫線處代碼有錯,請改正.
Dim n,s As Integer'n為試題計數(shù)器,s為得分
Dim a,b As Integer'a,b 為兩個運算數(shù)
Dim c As String'c為運算符:“+“表示加法,“-“表示減法
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為運算數(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.某智能農場啟用了根據土壤濕度自動控制噴淋裝置進行澆水的信息系統(tǒng),每隔一段時間,系統(tǒng)自動檢測土壤濕度,當土壤濕度低于某個閾值時將自動澆水。小李為統(tǒng)計出某段時間內(不超過100個時間單位)系統(tǒng)自動控制澆水的次數(shù)和該時間段內前后兩次啟動自動澆水系統(tǒng)的最大時間間隔單位,小李進行了數(shù)據分析,他認為如果某單位時間的土壤濕度比前一單位時間的土壤濕度高并且本單位時間內沒有下雨,則認為啟用了澆水系統(tǒng)。由此他編寫了一個VB程序實現(xiàn)該功能:在文本框Text1中輸入某段時間內的濕度值,在文本框Text2中輸入該段時間內對應的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動澆水次數(shù),Text4中顯示前后兩次自動澆水系統(tǒng)啟用的最大時間間隔單位。
(1)在Private Sub Command1_Click( ?。┲?,Command1、Click分別表示
(2)實現(xiàn)上述功能的VB程序如下,請在畫線處填入合適的代碼。
(3)程序中加框處代碼有錯,請改正。發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3