創(chuàng)意機(jī)器??賽——撿硬幣。?賽規(guī)則如下:
(1)在?賽場地上放置了n 個硬幣,每個硬幣的位置均不相同,各位置坐標(biāo)(x,y)保存在?本?件中(如圖所示,放置了5個硬幣,?本中坐標(biāo)按x,y 升序排列);
(2)機(jī)器?在兩個硬幣位置間?直線,從起點(diǎn)(0,0)出發(fā),按硬幣x 坐標(biāo)從?到?去撿,若 x 坐標(biāo)相同,則按 y 坐標(biāo)從?到?撿;取?其中的n-1個硬幣,總??距離最短的機(jī)器?將獲得?賽的冠軍。
例:如圖a 所示,p2直接到p4則代表p3處硬幣未取。
完成該項(xiàng)?分以下?個步驟:
(1)讀取坐標(biāo)數(shù)據(jù)。
從?本?件中讀取硬幣的坐標(biāo)(x、y),分別存儲在列表x 和y 中。請?jiān)跈M線處填?合適的代碼。
(2)編寫函數(shù),計(jì)算兩點(diǎn)間的距離。請?jiān)跈M線處填?合適的代碼。
(3)設(shè)計(jì)算法與程序?qū)崿F(xiàn)。
機(jī)器?取?n-1個硬幣經(jīng)過的最短距離公式可以描述為:
其中:為機(jī)器?取?n-1個硬幣?的最短距離;
為機(jī)器?取?n 個硬幣經(jīng)過的距離之和;
為機(jī)器?未取第i 個硬幣少?的路程;
Max 為求中的最?值。
根據(jù)上述算法編寫的Python 程序如下,請?jiān)跈M線處填?合適的代碼。
(4)調(diào)試和異常處理。
當(dāng)最后一個硬幣未取為最短距離時,上述程序運(yùn)?結(jié)果不正確。加框處代碼有誤,請修改。
【考點(diǎn)】事件處理過程.
【答案】見試題解答內(nèi)容
【解答】
【點(diǎn)評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:1引用:1難度:0.3
相似題
-
1.漢諾塔問題如圖所示,現(xiàn)要求將塔座A上的所有圓盤移到塔座B上,并仍按同樣順序疊放。移動圓盤時,需遵守漢諾塔問題的移動規(guī)則。由此,可設(shè)計(jì)出解漢諾塔問題的遞歸算法為( ?。?/h2>
發(fā)布:2024/11/14 8:0:1組卷:1引用:2難度:0.2 -
2.有如下Python程序段:
輸入s值為“13Ka5iSh79“,執(zhí)行該程序段后,輸出的結(jié)果是( ?。?/h2>發(fā)布:2025/1/2 9:0:7組卷:1引用:2難度:0.4 -
3.輸出列表a中的元素的最大值。不要更改程序結(jié)構(gòu),將題中的①②③填入正確的語句。
(1)序號①答案為:
A.range(1,5)
B.range(5)
C.a(chǎn)
D.a(chǎn)[4]
(2)序號②答案為:
A.maxx+=1
B.k=maxx
C.maxx=k
D.k+=1
(3)序號③答案為:
A.k
B.maxx
C.a(chǎn)[4]
D.a(chǎn)發(fā)布:2025/1/2 10:0:2組卷:0引用:2難度:0.4
把好題分享給你的好友吧~~