小張用VB模擬實現(xiàn)了一個打地鼠游戲的計分程序。游戲規(guī)則如下:總共有10個地鼠洞,每秒地鼠選擇一個洞探出腦袋,如果當(dāng)前的錘子在該洞口,則打中地鼠,否則沒有打中。游戲時間總共t秒(t<=10,Text1中輸入),錘子的起始位置在b(1)(Text2中輸入)。現(xiàn)已知每個時刻地鼠探腦袋的位置,根據(jù)錘子移動的路線,計算得出最多的得分,并輸出到 Labe1l。
錘子移動規(guī)則:錘子每秒必須往左或往右移動一步(不可在當(dāng)前位置停留),如果錘子已經(jīng)在最左邊了,只能往右移動;反之,只能往左移動。
計分方式:如果打中一個地鼠,計1分;如果連續(xù)打中地鼠,分?jǐn)?shù)翻倍,即連續(xù)打中兩個,分?jǐn)?shù)為1+2;連續(xù)打中三個,分?jǐn)?shù)為1+2+4;連續(xù)打中四個,分?jǐn)?shù)為1+2+4+8……
算法思路:
①隨機產(chǎn)生在第i秒時,地鼠探出腦袋的洞口為j。
若每個時刻地鼠探腦袋的洞口如圖a所示,以10個洞口為橫坐標(biāo)n,游戲時間t(假設(shè)t=10)為縱坐標(biāo),建立一個矩陣a。當(dāng)前時間出現(xiàn)地鼠的洞口標(biāo)記為1,其余默認(rèn)為0。
②模擬第i秒敲擊洞口的位置。
1)若輸入游戲過程如圖b所示,從5號洞口出發(fā)b(1)=5,當(dāng)時間為i=1時,可到達的洞口有2種:j=2時b(2)=6,j=1時b(1)=4,即得矩陣a的坐標(biāo)位置i和b(j);
2)同理當(dāng)i=2時,可到達的洞口有4種:j=4時b(4)=7,=3時b(3)=5,=2時b(2)=5,j=1時b(1)=3.i=1敲擊洞口位置為6或4;i=2敲擊洞口位置6→7,6-5或4→5,4→3;
3)將t秒內(nèi)可經(jīng)過的2t種不同路徑敲擊的矩陣位置的值存放到數(shù)組p中,如圖b所示得到其中某一條路徑p(j)=0101100010,根據(jù)p(j)計算得分,找出最值max并輸出。
(1)如果游戲時間為10秒,每秒地鼠出現(xiàn)的洞口序號依次為[9,9,9,10,10,10,10,9,9,9],當(dāng)錘子的起始位置在第6個洞口時,最多能得 55分。
(2)實現(xiàn)上述功能的VB程序如下,請在橫線處填入合適的代碼。
Private Sub Command1_Click ( ?。?br />Const n=10
Dim a(1 To n*n)As Integer,b(1 To 2^n)As Integer
Dim p(1 To 2^n)As String,s1 As String
Dim i As Integer,j As Integer,k As Integer,max As Integer
Dim t As Integer,s As Integer,f As Integer
Randomize
t=Val(Text1.Text)
For i=1 To t'第i秒時,地鼠探出腦袋的洞口為j
j=Int(Rnd*n+1)
①a((i-1)*n+j)=1a((i-1)*n+j)=1
List1.AddItem Str(i) &Str(j)
Next i
s1=““
For i=1 To t*n
s1=s1+Str(a(i))
If i Mod n=0 Then List2.AddItem s1:s1=““
Next i
b(1)=Val(Text2.Text)
For i=1 To n'計算錘子在a矩陣移動的路徑,并存放在p數(shù)組
k=1'k為正則向右移動錘子,k為負(fù)則向左移動錘子
For j=2^i To 1 Step-1
b(j)=b((j+1)\2)+k
If b(j)<1 Or b(j)>n Then b(j)=b(j)-2*k
p(j)=p((j+1)\2)+CStr( ②a((i-1)*n+b(j))a((i-1)*n+b(j)))'CStr功能類似Str
k=-k
Next j
Next i
max=0
For i=1 To 2^n
f=0:s=0:j=1
Do While j<=Len(p(i))
If Val(Mid(p(i),j,1))>0 Then
③f=f*2+Val(Mid(p(i),j,1))f=f*2+Val(Mid(p(i),j,1))
Else
s=s+f:f=0
End If
j=j+1
Loop
If f>0 Then s=s+f
If max<s Then max=s
Next i
Label1.Caption=“最多能得“+Str(max)+“分“
End Sub
【考點】應(yīng)用程序的試運行和保存.
【答案】5;a((i-1)*n+j)=1;a((i-1)*n+b(j));f=f*2+Val(Mid(p(i),j,1))
【解答】
【點評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:1引用:1難度:0.3
相似題
-
1.大部分社交軟件都有好友推薦的功能,當(dāng)用戶 A 和用戶 B 的共同好友數(shù)量超過閾值 p 時,由系統(tǒng)向用戶 A 推薦用戶 B。
編寫 VB 程序,實現(xiàn)好友推薦功能。運行程序,列表框 Listl 中顯示用戶 id 及好友列表,在文本框 Textl 中 輸入推薦目標(biāo)用戶 id,在文本框 Text2 中輸入閾值 p,點擊“推薦”按鈕,在列表框List2 中顯示用戶之間的關(guān)系,在標(biāo)簽 Label5 中顯示向目標(biāo)用戶推薦的好友列表。程序運行界面如圖:
(1)根據(jù)如圖所示數(shù)據(jù),若輸入用戶 id 為“3”,輸入閾值為“3”,則推薦好友為:
(2)實現(xiàn)上述功能的 VB 程序如下,請在橫線處填入合適的代碼。發(fā)布:2025/1/2 10:30:2組卷:0引用:1難度:0.3 -
2.小明用python語言中對大小為100*100像素的圖像“上.jpg”(如圖所示)進行簡單處理,部分代碼如圖:
程序執(zhí)行后的圖像效果是( )發(fā)布:2024/12/20 9:30:2組卷:3引用:5難度:0.4 -
3.某學(xué)校開展了藝術(shù)節(jié)活動,數(shù)組a中存儲了n個節(jié)目的編號和得分?jǐn)?shù)據(jù),數(shù)組存儲結(jié)構(gòu)如圖所示:
小明使用選擇排序思想對上述n個節(jié)目按得分進行降序排序(得分相同的按編號升序排列),并依據(jù)得分插入各個節(jié)目的排名信息,處理后數(shù)組a的存儲結(jié)構(gòu)如圖所示:
程序運行時,單擊命令按鈕Command1后讀取數(shù)據(jù)到數(shù)組a中并顯示在列表框List1中,單擊命令按鈕Command2后將節(jié)目按照上述規(guī)則進行排序,并將排名結(jié)果顯示在列表框List2中。
實現(xiàn)上述功能的VB程序如下,請回答下列問題:
(1)已知窗體名稱為Forml,要使程序加載時,窗體標(biāo)題自動顯示為“第15題程序”,則可在
(2)請在橫線處填入合適的代碼。
(3)加框處代碼有誤,請改正。發(fā)布:2025/1/2 10:30:2組卷:0引用:1難度:0.3
把好題分享給你的好友吧~~