用一個(gè)6*5矩陣表示地圖,分別用a數(shù)組元素表示,第1行從左到右為a(1)到a(6),依此類推,右下角為a(30)。其中數(shù)字0表示不通,數(shù)字1表示暢通。現(xiàn)在要從左上角到右下角尋找一條暢通的路徑。線路規(guī)則如下:
?路線每個(gè)點(diǎn)只能向右或向下
?任何一個(gè)岔口優(yōu)先向右走,右側(cè)不通再向下走
?一條路線中每個(gè)點(diǎn)只能走一次,不能重復(fù)
算法思路:探路過(guò)程中,記錄每個(gè)坐標(biāo)到數(shù)組lu;遇到岔路口(向右向下都通),則記錄路口坐標(biāo)到數(shù)組cha;遇到前方無(wú)路時(shí),需要返回到上一個(gè)路口,標(biāo)記路口右側(cè)坐標(biāo)為0;當(dāng)前方無(wú)路,岔路口數(shù)組也退回到0,說(shuō)明整體不通,否則根據(jù)規(guī)則走到右下為止,最后輸出整體線路坐標(biāo)。
實(shí)現(xiàn)算法的程序如下,運(yùn)行結(jié)果如右圖所示。
回答下列問(wèn)題:
(1)根據(jù)規(guī)則,如圖迷宮矩陣正確路線的第6個(gè)點(diǎn)是a數(shù)組的第 2121個(gè)元素(填數(shù)字)
(2)在程序橫線處填上合適代碼,使程序完整。
![](http://img.jyeoo.net/quiz/images/201904/115/a31320cb.png)
Dim a(1 To 50)As Integer
Private Sub Command1_Click ( ?。?br />Dim i As Integer,j As Integer,pos As Integer
Dim cha(1 To 10)As Integer'記錄一條線路中各個(gè)岔路口坐標(biāo)
Dim lu(1 To 10)As Integer'記錄路線經(jīng)過(guò)的坐標(biāo)
pos=1:j=0:lu(1)=1:i=1
Do While i<=9‘第1個(gè)和最后1個(gè)固定,中間有9個(gè)需要路過(guò)的坐標(biāo)
If pos Mod 6<>0 And a(zb+1)=1 Then'向右暢通
If pos+6<=30 and a(zb+6)=1 Then‘記錄岔路口
j=j+1
①cha(j)=poscha(j)=pos
End If
pos=pos+1
i=i+1
②lu(i)=poslu(i)=pos
ElseIf pos+6<=30 And a(pos+6)=1 Then'向下暢通
pos=pos+6
i=i+1
lu(i)=pos
Else'坐標(biāo)退回到上一個(gè)岔路口
If j=0 Then Exit Do
Do While lu(i)<>cha(j)
③i=i-1i=i-1
Loop
a(cha(j)+1)=0’標(biāo)記此路口右側(cè)不可用
pos=cha(j)
j=j-1
End If
Loop
If j=0 Then
Text1.Text=“沒(méi)有暢通道路“
Else
For i=1 To 10
Text1.Text=Text1.Text+Str(lu(i))
Next i
End If
End Sub
【考點(diǎn)】編輯事件處理過(guò)程的代碼.
【答案】21;cha(j)=pos;lu(i)=pos;i=i-1
【解答】
【點(diǎn)評(píng)】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:0引用:1難度:0.9
相似題
-
1.根據(jù)AQI值判斷城市的空氣質(zhì)量。若城市的AQI值(整數(shù))不超過(guò)100則空氣質(zhì)量?jī)?yōu)良,否則空氣質(zhì)量有污染。當(dāng)輸入的AQI值為-1時(shí)則退出程序。不要更改程序結(jié)構(gòu),將題中的①②③④填入正確的語(yǔ)句。
city=input(“請(qǐng)輸入城市名:”)
AQI=int(input(“請(qǐng)輸入空氣質(zhì)量指數(shù)AQI的值:”))
①______ AQI!=-1:
if ②______:
print(city,“的空氣質(zhì)量?jī)?yōu)良。”)
③______:
print(city,“的空氣質(zhì)量有污染。”)
city=input(“請(qǐng)輸入城市名:”)
AQI=④(input(“請(qǐng)輸入空氣質(zhì)量指數(shù)AQI的值:”))
(1)序號(hào)①答案為
A.if
B.while
C.for
D.def
(2)序號(hào)②答案為
A.AQI>=100
B.AQI<=100
C.AQI>100
D.AQI<100
(3)序號(hào)③答案為
A.elif
B.break
C.if
D.else
(4)序號(hào)④答案為
A.int
B.float
C.str
D.else發(fā)布:2025/1/2 11:0:1組卷:0引用:0難度:0.4 -
2.一球從100米高度自由落下,每次落地后反跳回原高度的一半,再下落。編寫一個(gè)C程序,求它在第10次落地時(shí),其經(jīng)過(guò)了多少米?第10次反彈多高?
發(fā)布:2025/1/2 11:0:1組卷:0引用:3難度:0.3 -
3.利用海倫公式求解三角形面積。已知a,b,c為三角形的三條邊長(zhǎng),p為三角形的半周長(zhǎng),即p=(a+b+c)/2,計(jì)算此三角形面積S的海倫公式為:
。不要更改程序結(jié)構(gòu),將題中的①②③填入正確的語(yǔ)句。
import math#導(dǎo)入數(shù)學(xué)模塊
def hl(a,b,c):#定義求三角形面積的函數(shù)
p=①
s=math.jye.ai(②)#sqrt用于計(jì)算算術(shù)平方根
return ③#返回面積的值
a,b,c=3,4,5#邊長(zhǎng)依次賦值
print(“此三角形的面積S為:“,hl(a,b,c))
A. (a+b+c)/2 B.p*(p-a)*(p-b)*(p-c)
C. (a+b+c)*2 D.s
(2)序號(hào)②答案為
A.(a+b+c)/2 B.p*(p-a)*(p-b)*(p-c)
C.(a+b+c)*2 D.(3+4+5)/2
(3)序號(hào)③答案為
A.p B.s
C.p*(p-a)*(p-b)*(p-c) D.0發(fā)布:2025/1/2 11:0:1組卷:0引用:0難度:0.4