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

          小張用VB模擬實現了一個打地鼠游戲的計分程序。游戲規則如下:總共有10個地鼠洞,每秒地鼠選擇一個洞探出腦袋,如果當前的錘子在該洞口,則打中地鼠,否則沒有打中。游戲時間總共t秒(t<=10,Text1中輸入),錘子的起始位置在b(1)(Text2中輸入)。現已知每個時刻地鼠探腦袋的位置,根據錘子移動的路線,計算得出最多的得分,并輸出到 Labe1l。
          錘子移動規則:錘子每秒必須往左或往右移動一步(不可在當前位置停留),如果錘子已經在最左邊了,只能往右移動;反之,只能往左移動。
          計分方式:如果打中一個地鼠,計1分;如果連續打中地鼠,分數翻倍,即連續打中兩個,分數為1+2;連續打中三個,分數為1+2+4;連續打中四個,分數為1+2+4+8……
          算法思路:
          ①隨機產生在第i秒時,地鼠探出腦袋的洞口為j。
          若每個時刻地鼠探腦袋的洞口如圖a所示,以10個洞口為橫坐標n,游戲時間t(假設t=10)為縱坐標,建立一個矩陣a。當前時間出現地鼠的洞口標記為1,其余默認為0。
          ②模擬第i秒敲擊洞口的位置。
          1)若輸入游戲過程如圖b所示,從5號洞口出發b(1)=5,當時間為i=1時,可到達的洞口有2種:j=2時b(2)=6,j=1時b(1)=4,即得矩陣a的坐標位置i和b(j);
          2)同理當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秒內可經過的2t種不同路徑敲擊的矩陣位置的值存放到數組p中,如圖b所示得到其中某一條路徑p(j)=0101100010,根據p(j)計算得分,找出最值max并輸出。
          (1)如果游戲時間為10秒,每秒地鼠出現的洞口序號依次為[9,9,9,10,10,10,10,9,9,9],當錘子的起始位置在第6個洞口時,最多能得
          5
          5
          分。
          (2)實現上述功能的VB程序如下,請在橫線處填入合適的代碼。
          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'計算錘子在a矩陣移動的路徑,并存放在p數組
          k=1'k為正則向右移動錘子,k為負則向左移動錘子
          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))
          【解答】
          【點評】
          聲明:本試題解析著作權屬菁優網所有,未經書面同意,不得復制發布。
          發布:2024/4/20 14:35:0組卷:1引用:1難度:0.3
          相似題
          • 1.大部分社交軟件都有好友推薦的功能,當用戶 A 和用戶 B 的共同好友數量超過閾值 p 時,由系統向用戶 A 推薦用戶 B。
            編寫 VB 程序,實現好友推薦功能。運行程序,列表框 Listl 中顯示用戶 id 及好友列表,在文本框 Textl 中 輸入推薦目標用戶 id,在文本框 Text2 中輸入閾值 p,點擊“推薦”按鈕,在列表框List2 中顯示用戶之間的關系,在標簽 Label5 中顯示向目標用戶推薦的好友列表。程序運行界面如圖:

            (1)根據如圖所示數據,若輸入用戶 id 為“3”,輸入閾值為“3”,則推薦好友為:
             

            (2)實現上述功能的 VB 程序如下,請在橫線處填入合適的代碼。

            發布:2025/1/2 10:30:2組卷:0引用:1難度:0.3
          • 2.小明用python語言中對大小為100*100像素的圖像“上.jpg”(如圖所示)進行簡單處理,部分代碼如圖:

            程序執行后的圖像效果是(  )

            發布:2024/12/20 9:30:2組卷:3引用:5難度:0.4
          • 3.某學校開展了藝術節活動,數組a中存儲了n個節目的編號和得分數據,數組存儲結構如圖所示:

            小明使用選擇排序思想對上述n個節目按得分進行降序排序(得分相同的按編號升序排列),并依據得分插入各個節目的排名信息,處理后數組a的存儲結構如圖所示:


            程序運行時,單擊命令按鈕Command1后讀取數據到數組a中并顯示在列表框List1中,單擊命令按鈕Command2后將節目按照上述規則進行排序,并將排名結果顯示在列表框List2中。
            實現上述功能的VB程序如下,請回答下列問題:
            (1)已知窗體名稱為Forml,要使程序加載時,窗體標題自動顯示為“第15題程序”,則可在
             
            (單選,填字母:A.Form_Click(  )/B.Form_Load(  )/C.Forml_Click (  )/D.Forml_Load (  ))事件過程 中添加代碼:Forml.Caption=“第15題程序”。
            (2)請在橫線處填入合適的代碼。
            (3)加框處代碼有誤,請改正。

            發布:2025/1/2 10:30:2組卷:0引用:1難度:0.3
          APP開發者:深圳市菁優智慧教育股份有限公司| 應用名稱:菁優網 | 應用版本:5.0.7 |隱私協議|第三方SDK|用戶服務條款
          本網部分資源來源于會員上傳,除本網組織的資源外,版權歸原作者所有,如有侵犯版權,請立刻和本網聯系并提供證據,本網將在三個工作日內改正