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

小劉在研究n個數(shù)的冒泡排序算法時,發(fā)現(xiàn)可以從兩個方面進行優(yōu)化:
(1)在每遍冒泡過程中,若最后一次交換的是last與last-1位置的數(shù),則last位置之前的相鄰數(shù)據(jù)均已有序.進行下一遍冒泡時,無序區(qū)域設(shè)置為[last,n],這樣一遍排序可能使當前無序區(qū)域縮?。?br />(2)若在某一遍排序中沒有數(shù)據(jù)交換,說明待排序數(shù)據(jù)都已經(jīng)有序,冒泡排序過程可在此遍排序后終止.因此可以引入一個邏輯變量flag,記錄在每遍排序過程中是否發(fā)生了交換,每遍排序結(jié)束時檢查flag,若未發(fā)生過交換則終止排序.
    小劉按上述方法編寫的冒泡優(yōu)化VB程序,功能如下:單擊“生成數(shù)據(jù)”按鈕Commandl后,生成一組隨機的兩位整數(shù)存入數(shù)組a,并顯示在列表框Listl中.單擊“排序”按鈕Command2后,對數(shù)組a 中的數(shù)據(jù)進行降序排序,排序后的數(shù)據(jù)顯示在列表框List2中,排序過程中實際的 泡遍數(shù)顯示在標簽Label2上.程序運行界面如圖所示.
菁優(yōu)網(wǎng)
    實現(xiàn)上述功能的VB程序如下,請回答下列問題:
(1)若按小劉優(yōu)化后的冒泡排序算法,對數(shù)據(jù)28,15,10,8,12進行降序排序,冒泡的遍數(shù)為
2
2
(填數(shù)字).
(2)請在①②③橫線處填入合適的代碼.
Dim a(1 To 20)As Integer
Private Sub Command1_Click( ?。?br />Dim i As Integer,j As Integer
Listl.Clear:List2.Clear
Randomize
’產(chǎn)生20個無重復(fù)的隨機整數(shù),范圍為[10,99],并存儲在數(shù)組a中
For i=1 To 20
a(i)=
①Rnd( ?。?90+10
①Rnd( ?。?90+10

j=1
For j=1 To i-1
If a(i)=a(j)Then
i=i-1
Exit For’退出循環(huán)
End If
Next j
Next i
For i=1 To 20
Listl.Addltem Str(a(i))
Next i
End Sub
Private Sub Command2_Click( ?。?br />Dim flag As Boolean,i As Integer,j As Integer
Dim temp As Integer,num As Integer,last As Integer
num=0:last=1
flag=True
Do While
②flag=true
②flag=true

flag=False
For
③j=20 To last+1 Step-1
③j=20 To last+1 Step-1

If  a(j)>a(j-1)Then
temp=a(j):a(j)=a(j-1):a(j-1)=temp
last=j
flag=True’有交換發(fā)生
End If
Next j
num=num+1
Loop
For i=1 To 20
List2.Additem Str(a(i))
Next i
Label3.Caption=〃本次排序的冒泡遍數(shù)為:〃& Str(num)
End Sub.

【答案】2;①Rnd(  )*90+10;②flag=true;③j=20 To last+1 Step-1
【解答】
【點評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:13引用:1難度:0.1
相似題
  • 1.運行列表框?qū)ο笳Z句:List1.AddItem=“同學們好!“,會顯示:同學們好?。?!--BA-->
     
    (判斷對錯)

    發(fā)布:2025/1/2 11:30:1組卷:6引用:6難度:0.9
  • 2.某智能農(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)對應(yīng)的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動澆水次數(shù),Text4中顯示前后兩次自動澆水系統(tǒng)啟用的最大時間間隔單位。
    菁優(yōu)網(wǎng)
    (1)在Private Sub Command1_Click( ?。┲?,Command1、Click分別表示
     
    (單選,填字母:A.對象名、屬性名/B.對象名、事件名/C.類名、方法名)。
    (2)實現(xiàn)上述功能的VB程序如下,請在畫線處填入合適的代碼。
    (3)程序中加框處代碼有錯,請改正。
    菁優(yōu)網(wǎng)菁優(yōu)網(wǎng)

    發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3
  • 菁優(yōu)網(wǎng)3.小張設(shè)計了一個“加減運算練習”VB程序.界面如下圖所示.單擊“出題”Command1按鈕顯示兩個運算數(shù)和運算符號,并計數(shù).在文本框Text1中輸入計算結(jié)果后單擊“判斷”按鈕Command2,如果計算結(jié)果正確,則得分加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(  )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為運算數(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
小程序二維碼
把好題分享給你的好友吧~~
APP開發(fā)者:深圳市菁優(yōu)智慧教育股份有限公司| 應(yīng)用名稱:菁優(yōu)網(wǎng) | 應(yīng)用版本:5.0.7 |隱私協(xié)議|第三方SDK|用戶服務(wù)條款
本網(wǎng)部分資源來源于會員上傳,除本網(wǎng)組織的資源外,版權(quán)歸原作者所有,如有侵犯版權(quán),請立刻和本網(wǎng)聯(lián)系并提供證據(jù),本網(wǎng)將在三個工作日內(nèi)改正