VB應用程序“跳遠成績排序”功能如下:
按指定格式錄入數據,例:0373,張樂曉,3.90.編號寬度固定為4位,姓名寬度固定為3個漢字,不足部分以全角空格補齊,第9個字符開始為跳遠成績.
在文本框Text1中按回車表示錄入一項數據結束,錄入的數據經處理后編號、姓名、成績分別存放在數組編號bh、xm、cj中并將原始數據顯示在List1中.
點擊命令按鈕Command1后進行排序并將排序后的結果顯示在List2中.程序運行界面如圖所示.
(1)請在橫線處填入適當的代碼
Dim bh(1To 8)As String
Dim xm(1To 8)As String
Dim cj(1To 8)As Single
Dim num As Integer
Private Sub Command1_Click ( ?。?br />Dim i As Integer,j As Integer,k As Integer,t1As String,t2As Single
For i=1To 7
k=i
For j=k+1To 8
If ①cj(j)<cj(k)cj(j)<cj(k)Then k=j
Next j
If k<>i Then
t1=bh(k):bh(k)=bh(i):bh(i)=t1
t1=xm(k):xm(k)=xm(i):xm(i)=t1
t2=cj(k):cj(k)=cj(i):cj(i)=t2
End If
Next i
For i=1To 8
List2.AddItem bh(i) &xm(i) &Str(cj(i))
Next i
End Sub
Private Sub Form_Load ( )
num=0
End Sub
Private Sub Text1_Keypress(KeyAsciiAs Integer)
Dim x As String'輸入數據
IfKeyAscii=13Then
num=num+1
x=Text1.Text
bh(num)=Mid(x,1,4)
xm(num)=Mid(x,6,3)
cj(num)=②Val(Mid(x,10,Len(x)-9))Val(Mid(x,10,Len(x)-9))
List1.AddItem x
If num=8Thennum=0
End If
End Sub
請完成以下題目:
(1)程序中①橫線處應填入 cj(j)<cj(k)cj(j)<cj(k);程序中②橫線處應填入 Val(Mid(x,10,Len(x)-9))Val(Mid(x,10,Len(x)-9)).
(2)在事件處理過程Command1_Click ( ?。┲胁捎玫乃惴ㄊ?選擇排序選擇排序(選填:枚舉算法/解析算法/冒泡排序/選擇排序).
【答案】cj(j)<cj(k);Val(Mid(x,10,Len(x)-9));cj(j)<cj(k);Val(Mid(x,10,Len(x)-9));選擇排序
【解答】
【點評】
聲明:本試題解析著作權屬菁優(yōu)網所有,未經書面同意,不得復制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:7引用:1難度:0.1
相似題
-
1.運行列表框對象語句:List1.AddItem=“同學們好!“,會顯示:同學們好!;
發(fā)布: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( ?。﹏=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.發(fā)布:2025/1/2 9:30:2組卷:6引用:2難度:0.9 -
3.某智能農場啟用了根據土壤濕度自動控制噴淋裝置進行澆水的信息系統,每隔一段時間,系統自動檢測土壤濕度,當土壤濕度低于某個閾值時將自動澆水。小李為統計出某段時間內(不超過100個時間單位)系統自動控制澆水的次數和該時間段內前后兩次啟動自動澆水系統的最大時間間隔單位,小李進行了數據分析,他認為如果某單位時間的土壤濕度比前一單位時間的土壤濕度高并且本單位時間內沒有下雨,則認為啟用了澆水系統。由此他編寫了一個VB程序實現該功能:在文本框Text1中輸入某段時間內的濕度值,在文本框Text2中輸入該段時間內對應的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統自動澆水次數,Text4中顯示前后兩次自動澆水系統啟用的最大時間間隔單位。
(1)在Private Sub Command1_Click( ?。┲校珻ommand1、Click分別表示
(2)實現上述功能的VB程序如下,請在畫線處填入合適的代碼。
(3)程序中加框處代碼有錯,請改正。發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3
把好題分享給你的好友吧~~