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

小張用VB模擬實(shí)現(xiàn)了一個打地鼠游戲的計(jì)分程序。游戲規(guī)則如下:總共有10個地鼠洞,每秒地鼠選擇一個洞探出腦袋,如果當(dāng)前的錘子在該洞口,則打中地鼠,否則沒有打中。游戲時間總共t秒(t<=10,Text1中輸入),錘子的起始位置在b(1)(Text2中輸入)?,F(xiàn)已知每個時刻地鼠探腦袋的位置,根據(jù)錘子移動的路線,計(jì)算得出最多的得分,并輸出到 Labe1l。
錘子移動規(guī)則:錘子每秒必須往左或往右移動一步(不可在當(dāng)前位置停留),如果錘子已經(jīng)在最左邊了,只能往右移動;反之,只能往左移動。
計(jì)分方式:如果打中一個地鼠,計(jì)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……
算法思路:
①隨機(jī)產(chǎn)生在第i秒時,地鼠探出腦袋的洞口為j。菁優(yōu)網(wǎng)
若每個時刻地鼠探腦袋的洞口如圖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時,可到達(dá)的洞口有2種:j=2時b(2)=6,j=1時b(1)=4,即得矩陣a的坐標(biāo)位置i和b(j);
2)同理當(dāng)i=2時,可到達(dá)的洞口有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)計(jì)算得分,找出最值max并輸出。
(1)如果游戲時間為10秒,每秒地鼠出現(xiàn)的洞口序號依次為[9,9,9,10,10,10,10,9,9,9],當(dāng)錘子的起始位置在第6個洞口時,最多能得
5
5
分。
(2)實(shí)現(xiàn)上述功能的VB程序如下,請?jiān)跈M線處填入合適的代碼。
Private Sub Command1_Click (  )
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)=1
a((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'計(jì)算錘子在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

【答案】5;a((i-1)*n+j)=1;a((i-1)*n+b(j));f=f*2+Val(Mid(p(i),j,1))
【解答】
【點(diǎn)評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:0引用:1難度:0.3
相似題
  • 1.有如下程序段:
    For i=1 To Len(Text1.Text)
    c=Mid(Text1.Text,i,1)
    If c>=“0“And c<=“9“Then c=Chr(Asc(c)+1)
    If c>=“A“And c<=“Z“Then c=Chr(Asc(c)+32)
    s=s+c
    Next i
    若文本框Text1的內(nèi)容為“Number 2468!”執(zhí)行程序后,變量s的值為( ?。?/h2>

    發(fā)布:2024/11/11 11:30:2組卷:4引用:3難度:0.3
  • 2.小明想要在數(shù)字串s中尋找連續(xù)數(shù)字之和為k 的子串,若有多個子串符合,則輸出第一個子串。例如,s=“20220520“,k=7,則符合要求的子串為“205“。實(shí)現(xiàn)該功能的部分python代碼如圖:
    菁優(yōu)網(wǎng)
    劃線①②處的語句是(  )

    發(fā)布:2024/11/5 21:30:2組卷:3引用:3難度:0.5
  • 3.有如下VB程序段:
    菁優(yōu)網(wǎng)
    執(zhí)行以上程序段后,Text1中顯示的值可能是( ?。?/h2>

    發(fā)布:2024/11/11 18:0:1組卷:0引用:1難度:0.5
小程序二維碼
把好題分享給你的好友吧~~
APP開發(fā)者:深圳市菁優(yōu)智慧教育股份有限公司 | 應(yīng)用名稱:菁優(yōu)網(wǎng) | 應(yīng)用版本:4.8.2  |  隱私協(xié)議      第三方SDK     用戶服務(wù)條款廣播電視節(jié)目制作經(jīng)營許可證出版物經(jīng)營許可證網(wǎng)站地圖本網(wǎng)部分資源來源于會員上傳,除本網(wǎng)組織的資源外,版權(quán)歸原作者所有,如有侵犯版權(quán),請立刻和本網(wǎng)聯(lián)系并提供證據(jù),本網(wǎng)將在三個工作日內(nèi)改正