用VB編寫一個(gè)模擬在900個(gè)觀眾中產(chǎn)生10個(gè)中獎(jiǎng)號(hào)碼的程序,每位觀眾用三位數(shù)字進(jìn)行編號(hào),要求產(chǎn)生的10個(gè)號(hào)碼不能重復(fù),并且升序排列輸出.
①檢查產(chǎn)生號(hào)碼是否重復(fù):把產(chǎn)生的中獎(jiǎng)號(hào)碼放在數(shù)組a中,新生的號(hào)碼與已經(jīng)產(chǎn)生的號(hào)碼進(jìn)行一一對(duì)比,如果找到相等的數(shù),則重新產(chǎn)生新號(hào)碼.
②找到新產(chǎn)生號(hào)碼存放的數(shù)組下標(biāo):從下標(biāo)為1的數(shù)組元素開始,新號(hào)碼(第i個(gè)號(hào)碼)分別與他們進(jìn)行一一比較,找到第一個(gè)比新號(hào)碼大的數(shù),該數(shù)所在的下標(biāo)就是新號(hào)碼應(yīng)存放的下標(biāo).如果在已經(jīng)產(chǎn)生的數(shù)中沒有找到比新號(hào)碼大的數(shù),則新號(hào)碼應(yīng)存放在下標(biāo)為i的數(shù)組元素中.下表以產(chǎn)生第5個(gè)號(hào)碼為例,如果產(chǎn)生的號(hào)碼是150,第一個(gè)比他大的數(shù)是a(2),下標(biāo)為2的數(shù)組元素應(yīng)存放新號(hào)碼;如果產(chǎn)生的號(hào)碼是300,則新號(hào)碼應(yīng)存放在下標(biāo)為5的數(shù)組元素中.
數(shù)組元素 | a(1) | a(2) | a(3) | a(4) |
數(shù)組元素的值 | 120 | 188 | 211 | 278 |
④將新產(chǎn)生的號(hào)碼放在相應(yīng)的數(shù)組元素中.
程序運(yùn)行的界面如圖所示,實(shí)現(xiàn)上述功能的VB程序代碼如下:
Dim a(10)As Single
Private Sub Command1_Click ( ?。?br />Dim i As Integer,j As Integer
Dim temp As Single,k As Integer‘temp產(chǎn)生隨機(jī)數(shù),k隨機(jī)數(shù)存放數(shù)組元素的下標(biāo)
Randomize
a(1)=Int(Rnd ( ?。?900+100)
For i=2To 10
temp=Int(Rnd ( ?。?900+100)
If seach(temp,i-1)=True Then
i=i-1
Else
For j=-1To k Step-1
a(j+1)=a(j)
Next j
a(k)=temp
a(k)=temp
End If
Next i
List1.Clear
For i=1To 10
List1.AddItem Str(a(i))
Next i
End Sub
‘函數(shù)實(shí)現(xiàn)在數(shù)組a中,從下標(biāo)為1的數(shù)組元素到下標(biāo)為t數(shù)組元素,查找有無pp的數(shù)值
Function seach(pp As Single,t As Integer) As Boolean
Dim i As Integer
seach=False
For i=1To t
If
pp=a(i)
pp=a(i)
Then seach=True:Exit ForNext i
End Function
(1)程序中橫線處①應(yīng)填入
a(k)=temp
a(k)=temp
程序中橫線處②應(yīng)填入 pp=a(i)
pp=a(i)
(2)加框處的程序段實(shí)現(xiàn)的功能是
找到新產(chǎn)生號(hào)碼存放的數(shù)組下標(biāo)
找到新產(chǎn)生號(hào)碼存放的數(shù)組下標(biāo)
.【考點(diǎn)】對(duì)象的屬性、方法和事件;編輯事件處理過程的代碼.
【答案】a(k)=temp;pp=a(i);a(k)=temp;pp=a(i);找到新產(chǎn)生號(hào)碼存放的數(shù)組下標(biāo)
【解答】
【點(diǎn)評(píng)】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:0引用:1難度:0.3
相似題
-
1.運(yùn)行列表框?qū)ο笳Z句:List1.AddItem=“同學(xué)們好!“,會(huì)顯示:同學(xué)們好?。?!--BA-->
發(fā)布:2025/1/2 11:30:1組卷:6引用:6難度:0.9 -
2.某智能農(nóng)場啟用了根據(jù)土壤濕度自動(dòng)控制噴淋裝置進(jìn)行澆水的信息系統(tǒng),每隔一段時(shí)間,系統(tǒng)自動(dòng)檢測土壤濕度,當(dāng)土壤濕度低于某個(gè)閾值時(shí)將自動(dòng)澆水。小李為統(tǒng)計(jì)出某段時(shí)間內(nèi)(不超過100個(gè)時(shí)間單位)系統(tǒng)自動(dòng)控制澆水的次數(shù)和該時(shí)間段內(nèi)前后兩次啟動(dòng)自動(dòng)澆水系統(tǒng)的最大時(shí)間間隔單位,小李進(jìn)行了數(shù)據(jù)分析,他認(rèn)為如果某單位時(shí)間的土壤濕度比前一單位時(shí)間的土壤濕度高并且本單位時(shí)間內(nèi)沒有下雨,則認(rèn)為啟用了澆水系統(tǒng)。由此他編寫了一個(gè)VB程序?qū)崿F(xiàn)該功能:在文本框Text1中輸入某段時(shí)間內(nèi)的濕度值,在文本框Text2中輸入該段時(shí)間內(nèi)對(duì)應(yīng)的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動(dòng)澆水次數(shù),Text4中顯示前后兩次自動(dòng)澆水系統(tǒng)啟用的最大時(shí)間間隔單位。
(1)在Private Sub Command1_Click( ?。┲?,Command1、Click分別表示
(2)實(shí)現(xiàn)上述功能的VB程序如下,請(qǐng)?jiān)诋嬀€處填入合適的代碼。
(3)程序中加框處代碼有錯(cuò),請(qǐng)改正。發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3 -
3.小張?jiān)O(shè)計(jì)了一個(gè)“加減運(yùn)算練習(xí)”VB程序.界面如下圖所示.單擊“出題”Command1按鈕顯示兩個(gè)運(yùn)算數(shù)和運(yùn)算符號(hào),并計(jì)數(shù).在文本框Text1中輸入計(jì)算結(jié)果后單擊“判斷”按鈕Command2,如果計(jì)算結(jié)果正確,則得分加10分,直至完成10題測試.VB程序如下,但加下橫線處代碼有錯(cuò),請(qǐng)改正.
Dim n,s As Integer'n為試題計(jì)數(shù)器,s為得分
Dim a,b As Integer'a,b 為兩個(gè)運(yùn)算數(shù)
Dim c As String'c為運(yùn)算符:“+“表示加法,“-“表示減法
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為運(yùn)算數(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
把好題分享給你的好友吧~~