星期天小明來到動(dòng)物園游玩,園內(nèi)共有n個(gè)景點(diǎn),每個(gè)景點(diǎn)序號(hào)為0,1,2,3……n-1?,F(xiàn)在只知道每個(gè)景點(diǎn)有一條路連接下一個(gè)景點(diǎn)。小明想尋找能游玩景點(diǎn)個(gè)數(shù)最多的一種方案并且從其中一個(gè)景點(diǎn)出發(fā),最后能夠回到出發(fā)景點(diǎn)。如果游玩的景點(diǎn)個(gè)數(shù)一樣,則優(yōu)先考慮景點(diǎn)序號(hào)小的。例如,共有 n=5 個(gè)景點(diǎn),每個(gè)景點(diǎn)連接的下個(gè)景點(diǎn)分別是1,3,4,4,1
景點(diǎn)號(hào) | 0 | 1 | 2 | 3 | 4 |
下一個(gè)景點(diǎn)號(hào) | 1 | 3 | 4 | 4 | 1 |
方案二:從 1 號(hào)景點(diǎn)出發(fā),則游玩線路為:1 號(hào)→3 號(hào)→4 號(hào)→1 號(hào),然后回到1號(hào)景點(diǎn)。最多可以玩3個(gè)景點(diǎn)。
現(xiàn)用Python程序模擬這個(gè)問題:
先輸入景點(diǎn)總數(shù):n;則對(duì)應(yīng)的景點(diǎn)為[0,1,2,3,4]
然后隨機(jī)產(chǎn)生各景點(diǎn)所連接的下一個(gè)景點(diǎn)的序號(hào),如:[1,3,4,4,1];
接著產(chǎn)生一個(gè)列表,如上表的信息則產(chǎn)生的列表 s 為:[[0,1],[1,3],[2,4],[3,4],[4,1]],
最后利用鏈表的方式來分析解決問題。程序如下,請(qǐng)將橫線處補(bǔ)充完整并修改加框處。

import random
#產(chǎn)生信息列表 s
n=int(input(“景點(diǎn)總數(shù)“))
tt=( ?。籹=( ?。籧=0
while c<n:
t=random.randint(0,n-1)
if t!=c:
s.jye.ai([①
c,t
c,t
])c+=1
print(s)
#枚舉所有方案,尋找正確方案。
max=0
for head in range(n):
p=head
k=1
while k<=n and s[p][1]!=head:
k+=1
p=s[p][1]
if k>max ②:②處應(yīng)修改為
s[p][1]==head and k>max
s[p][1]==head and k>max
max=k
maxp=head
print(“小明最多能訪問%d 個(gè)景點(diǎn)“%(max))
#輸出正確線路
p=maxp
while s[p][1]!=maxp:
print(s[p][0],end=“→“)
p=s[p][1]
print(③
s[p][0]
s[p][0]
)【考點(diǎn)】編輯事件處理過程的代碼.
【答案】c,t;s[p][1]==head and k>max;s[p][0]
【解答】
【點(diǎn)評(píng)】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/12/5 1:0:2組卷:5引用:1難度:0.3
相似題
-
1.根據(jù)AQI值判斷城市的空氣質(zhì)量。若城市的AQI值(整數(shù))不超過100則空氣質(zhì)量?jī)?yōu)良,否則空氣質(zhì)量有污染。當(dāng)輸入的AQI值為-1時(shí)則退出程序。不要更改程序結(jié)構(gòu),將題中的①②③④填入正確的語句。
city=input(“請(qǐng)輸入城市名:”)
AQI=int(input(“請(qǐng)輸入空氣質(zhì)量指數(shù)AQI的值:”))
①______ AQI!=-1:
if ②______:
print(city,“的空氣質(zhì)量?jī)?yōu)良?!保?br />③______:
print(city,“的空氣質(zhì)量有污染?!保?br />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)過了多少米?第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),將題中的①②③填入正確的語句。
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
相關(guān)試卷