小王編寫了一個依據成績統計名次的VB程序,成績為0到100之間的整數.算法的基本思想:先統計每個分數的個數,然后按照分數從高到低依次計算每個有效分數(該分數的個數不為0)對應的名次,分數相同時名次并列.最高分為第1名,該分數的名次與個數之和為下一個有效分數的名次,以此類推.程序用數組A存放每個分數對應的個數,數組B存放每個分數對應的名次.例如,下表中最高分100分有2個,并列第1名,則分數96的名次為分數100的名次加上分數100的個數,即第3名.
分數 | 100 | 99 | 98 | 97 | 96 | 95 | 94 | … | 0 |
個數(A數組) | 2 | 0 | 0 | 0 | 1 | 0 | 3 | 0 | |
名次(B數組) | 1 | 3 | 4 |

實現上述功能的VB程序如下:請回答下列問題:
(1)如表示,若分數93的個數為2,則該分數對應的名次為
7
7
.(2)請在橫線處填入合適的代碼
Dim sName(1to 50)As String‘存放學生姓名
Dim sScore(1to 50)As Integer’存放學生分數
Dim recount As Integer’存放學生人數
Private Sub Form_load ( )
‘本過程從數據庫中讀取學生數據,存儲在相應的變量中,并在List1中顯示
‘代碼略
End Sub
‘整數轉換成長度固定的字符串
Function ads(x As Integer,n As Integer)As string
Dim sx As String,nx As Integer,i As Integer
sx=Str(x):nx=Len(sx)
For i=1to n-nx
sx=””+sx
Next i
①
abs=sx
abs=sx
End Function
Private Sub Command1_click( )
Dim A(0to 100)As Integer’存放每個分數的個數
Dim B(0to 100)As Integer’存放每個分數的名次
Dim mc As Integer,score As integer,i As Integer
For i=0to 100⑧
A(i)=0
Next i
For i=1to recount’計算每個分數的個數
②
A(sScore(i))=A(sScore(i))+1
A(sScore(i))=A(sScore(i))+1
Next i
mc=1
For i=100to 0step-1’計算每個分數名次
If A(i)<>0Then
B(i)=mc
③
mc=mc+A(i)或mc=B(i)+A(i)
mc=mc+A(i)或mc=B(i)+A(i)
End if
Next i
List2.clear
List2.additem“姓名 分數 名次”
List2.additem”--------”
For i=1to recount
score=sScore(i)
mc=B(sScore(i))
list2.additem sName(i)+ads(score,5)+”第”+ads(mc,3)+”名”
Next i
End Sub.
【考點】對象的屬性、方法和事件;編輯事件處理過程的代碼.
【答案】7;abs=sx;A(sScore(i))=A(sScore(i))+1;mc=mc+A(i)或mc=B(i)+A(i)
【解答】
【點評】
聲明:本試題解析著作權屬菁優網所有,未經書面同意,不得復制發布。
發布:2024/4/20 14:35:0組卷:10引用:1難度:0.1
相似題
-
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分別表示
(2)實現上述功能的VB程序如下,請在畫線處填入合適的代碼。
(3)程序中加框處代碼有錯,請改正。發布:2025/1/2 11:0:1組卷:0引用:1難度:0.3