【加試題】n個數(shù)據(jù)的冒泡排序需要經(jīng)過n-1遍加工,每一遍加工自下而上比較相鄰兩個數(shù)據(jù),把較小者交換到上面.小劉發(fā)現(xiàn):當某一遍加工過程中沒有數(shù)據(jù)交換,說明數(shù)據(jù)已經(jīng)有序,無需進一步加工.為此,小劉對算法進行優(yōu)化,編寫了一個VB程序,功能如下:運行程序時,在列表框List1中顯示排序前數(shù)據(jù),單擊“排序”按鈕Commaiid1,在列表框List2 中顯示這些數(shù)據(jù)按升序排序后的結果,在標簽Label3中顯示排序過程的加工遍數(shù).運行效果如圖所示.

實現(xiàn)上述功能的VB代碼如下,但加框處代碼有錯,請改正.
Dim a(1To 8)As Integer
Dim n As Integer
Private Sub Form_Load( ?。?/div>( )
'n=8,排序前數(shù)據(jù)存儲在數(shù)組a中,并在列表框Listl中顯示
'代碼略
End Sub
Private Sub Command1_Click( ?。?/div>( ?。?/div>
Dim flag As Boolean'flag值為True表示一遍加工中發(fā)生過交換
i=1
flag=True
Do While'(1)i<=n-1Or flag=True
flag=False
For j=n To i+1Step-1
If a(j)<a(j-1)Then
k=a(j):a(j)=a(j-1):a(j-1)=k
flag=True
End If
Next j
i=i+1
Loop
Str(i)
Label3.Caption=“排序過程的加工遍數(shù)為“+'(2)
For i=1To n
List2.AddItem Str(a(i))
Next i
End Sub.【答案】( ?。唬ā 。?/div>【解答】【點評】聲明:本試題解析著作權屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復制發(fā)布。發(fā)布:2024/4/20 14:35:0組卷:14引用:5難度:0.1
相似題
-
1.運行列表框?qū)ο笳Z句: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.某智能農(nóng)場啟用了根據(jù)土壤濕度自動控制噴淋裝置進行澆水的信息系統(tǒng),每隔一段時間,系統(tǒng)自動檢測土壤濕度,當土壤濕度低于某個閾值時將自動澆水。小李為統(tǒng)計出某段時間內(nèi)(不超過100個時間單位)系統(tǒng)自動控制澆水的次數(shù)和該時間段內(nèi)前后兩次啟動自動澆水系統(tǒng)的最大時間間隔單位,小李進行了數(shù)據(jù)分析,他認為如果某單位時間的土壤濕度比前一單位時間的土壤濕度高并且本單位時間內(nèi)沒有下雨,則認為啟用了澆水系統(tǒng)。由此他編寫了一個VB程序?qū)崿F(xiàn)該功能:在文本框Text1中輸入某段時間內(nèi)的濕度值,在文本框Text2中輸入該段時間內(nèi)對應的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動澆水次數(shù),Text4中顯示前后兩次自動澆水系統(tǒng)啟用的最大時間間隔單位。

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


發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3
( )
'n=8,排序前數(shù)據(jù)存儲在數(shù)組a中,并在列表框Listl中顯示
'代碼略
End Sub
Private Sub Command1_Click
( ?。?/div>
( ?。?/div>
Dim flag As Boolean'flag值為True表示一遍加工中發(fā)生過交換
i=1
flag=True
Do While'(1)i<=n-1Or flag=True
flag=False
For j=n To i+1Step-1
If a(j)<a(j-1)Then
k=a(j):a(j)=a(j-1):a(j-1)=k
flag=True
End If
Next j
i=i+1
Loop
Str(i)
Label3.Caption=“排序過程的加工遍數(shù)為“+'(2)
For i=1To n
List2.AddItem Str(a(i))
Next i
End Sub.
Dim flag As Boolean'flag值為True表示一遍加工中發(fā)生過交換
i=1
flag=True
Do While'(1)i<=n-1Or flag=True
flag=False
For j=n To i+1Step-1
If a(j)<a(j-1)Then
k=a(j):a(j)=a(j-1):a(j-1)=k
flag=True
End If
Next j
i=i+1
Loop
Str(i)
Label3.Caption=“排序過程的加工遍數(shù)為“+'(2)
For i=1To n
List2.AddItem Str(a(i))
Next i
End Sub.
【答案】( ?。唬ā 。?/div>
【解答】
【點評】
聲明:本試題解析著作權屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:14引用:5難度:0.1
相似題
-
1.運行列表框?qū)ο笳Z句: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.某智能農(nóng)場啟用了根據(jù)土壤濕度自動控制噴淋裝置進行澆水的信息系統(tǒng),每隔一段時間,系統(tǒng)自動檢測土壤濕度,當土壤濕度低于某個閾值時將自動澆水。小李為統(tǒng)計出某段時間內(nèi)(不超過100個時間單位)系統(tǒng)自動控制澆水的次數(shù)和該時間段內(nèi)前后兩次啟動自動澆水系統(tǒng)的最大時間間隔單位,小李進行了數(shù)據(jù)分析,他認為如果某單位時間的土壤濕度比前一單位時間的土壤濕度高并且本單位時間內(nèi)沒有下雨,則認為啟用了澆水系統(tǒng)。由此他編寫了一個VB程序?qū)崿F(xiàn)該功能:在文本框Text1中輸入某段時間內(nèi)的濕度值,在文本框Text2中輸入該段時間內(nèi)對應的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動澆水次數(shù),Text4中顯示前后兩次自動澆水系統(tǒng)啟用的最大時間間隔單位。
(1)在Private Sub Command1_Click( ?。┲校珻ommand1、Click分別表示
(2)實現(xiàn)上述功能的VB程序如下,請在畫線處填入合適的代碼。
(3)程序中加框處代碼有錯,請改正。發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3
本網(wǎng)部分資源來源于會員上傳,除本網(wǎng)組織的資源外,版權歸原作者所有,如有侵犯版權,請立刻和本網(wǎng)聯(lián)系并提供證據(jù),本網(wǎng)將在三個工作日內(nèi)改正