試題 算法提高 學(xué)霸的迷宮

試題 算法提高 學(xué)霸的迷宮(bfs)


問(wèn)題描述
  學(xué)霸搶走了大家的作業(yè)宇智,班長(zhǎng)為了幫同學(xué)們找回作業(yè)蔓搞,決定去找學(xué)霸決斗。但學(xué)霸為了不要?jiǎng)e人打擾随橘,住在一個(gè)城堡里喂分,城堡外面是一個(gè)二維的格子迷宮,要進(jìn)城堡必須得先通過(guò)迷宮机蔗。因?yàn)榘嚅L(zhǎng)還有妹子要陪蒲祈,磨刀不誤砍柴功,他為了節(jié)約時(shí)間萝嘁,從線人那里搞到了迷宮的地圖梆掸,準(zhǔn)備提前計(jì)算最短的路線⊙姥裕可是他現(xiàn)在正向妹子解釋這件事情酸钦,于是就委托你幫他找一條最短的路線。
輸入格式
  第一行兩個(gè)整數(shù)n咱枉, m卑硫,為迷宮的長(zhǎng)寬。
  接下來(lái)n行庞钢,每行m個(gè)數(shù)拔恰,數(shù)之間沒(méi)有間隔,為0或1中的一個(gè)基括。0表示這個(gè)格子可以通過(guò)颜懊,1表示不可以。假設(shè)你現(xiàn)在已經(jīng)在迷宮坐標(biāo)(1,1)的地方,即左上角河爹,迷宮的出口在(n,m)匠璧。每次移動(dòng)時(shí)只能向上下左右4個(gè)方向移動(dòng)到另外一個(gè)可以通過(guò)的格子里,每次移動(dòng)算一步咸这。數(shù)據(jù)保證(1,1)夷恍,(n,m)可以通過(guò)。
輸出格式
  第一行一個(gè)數(shù)為需要的最少步數(shù)K媳维。
  第二行K個(gè)字符酿雪,每個(gè)字符∈{U,D,L,R},分別表示上下左右。如果有多條長(zhǎng)度相同的最短路徑侄刽,選擇在此表示方法下字典序最小的一個(gè)指黎。
樣例輸入
Input Sample 1:
3 3
001
100
110

Input Sample 2:
3 3
000
000
000
樣例輸出
Output Sample 1:
4
RDRD

Output Sample 2:
4
DDRR
思路:
從題意中可以看出此題是迷宮題只不過(guò)要算出如何走的位置和最短路相同時(shí)選擇在此表示方法下字典序最小的一個(gè)。
我們可以知道迷宮題是個(gè)經(jīng)典的bfs廣域思想題州丹,他的思想就是把開(kāi)頭隊(duì)列存到隊(duì)列中醋安,然在用一個(gè)列表存儲(chǔ)我走過(guò)的值,并記錄走的對(duì)應(yīng)軌跡墓毒。
我們第一步先建立一個(gè)函數(shù)bfs吓揪,然后在里面建存隊(duì)列的列表。
我用的是d 然后在存一個(gè)開(kāi)頭我們知道起點(diǎn)是(1所计,1)柠辞,但我從(0,0)開(kāi)始的個(gè)人習(xí)慣把醉箕。我們?cè)谟靡粋€(gè)字典鍵來(lái)存走過(guò)的路钾腺,值來(lái)存對(duì)應(yīng)的軌跡。然后我們需要按順序的從DLRU開(kāi)始走一步讥裤。因?yàn)轭}目說(shuō)了最短路相同時(shí)選擇在此表示方法下字典序最小的一個(gè),然后我們把走到下步的值用x1,y1存儲(chǔ)起來(lái)姻报, 然后我們就開(kāi)始判斷條件己英,我們首先不可以走走過(guò)的路,下面就是當(dāng)p[x1,y1]p字典有這個(gè)鍵時(shí)我們就不管吴旋。

try:
      p[x1,y1]
 except:

當(dāng)沒(méi)有時(shí)我們就判斷x1和y1是否超出界限"-1<x1<n and -1<y1<m " 然后在判斷是否是可以走的路mp[x1][y1]=="0"损肛。
當(dāng)上面條件都滿足時(shí)我們就把對(duì)應(yīng)點(diǎn)放入隊(duì)列中然后存儲(chǔ)到該點(diǎn)的軌跡,上個(gè)點(diǎn)的軌跡加現(xiàn)在是從那邊過(guò)來(lái)的反向就是本點(diǎn)的軌跡p[x1,y1]=p[x,y]+s[i]荣瑟。當(dāng)該點(diǎn)到終點(diǎn)時(shí)我們就算出終點(diǎn)走的軌跡治拿。
程序:

n,m=map(int,input().split())  
mp=[list(input()) for i in range(n)] #存入圖
s="DLRU"  
f=[[1,0],[0,-1],[0,1],[-1,0]]  #各個(gè)方向標(biāo)記
def bfs():
    p={}   #存儲(chǔ)軌跡及 位置
    d=[[0,0]]  #隊(duì)列存儲(chǔ)
    p[0,0]=""   #存儲(chǔ)第一個(gè)點(diǎn)的位置及 軌跡
    while d!=[]:
        x,y=d.pop(0)  #取出隊(duì)列的第一個(gè)點(diǎn)
        for i in range(4):
            x1=f[i][0]+x  #下個(gè)點(diǎn)的位置
            y1=f[i][1]+y
            try:
                p[x1,y1]  #判斷是否有當(dāng)前這個(gè)點(diǎn)
            except:
                if -1<x1<n  and -1<y1<m and mp[x1][y1]=="0"  :  #判斷是否超界限是否路可以走
                    d.append([x1,y1])  #存入列表中
                    p[x1,y1]=p[x,y]+s[i]  #記錄該點(diǎn)的軌跡
                    if x1==n-1 and m-1==y1:  #是否到達(dá)終點(diǎn)
                        return p[x1,y1]
c=bfs()
print(len(c))
print(c)

禁止轉(zhuǎn)載。僅用于自己學(xué)習(xí)笆焰。對(duì)程序錯(cuò)誤不負(fù)責(zé)劫谅。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子捏检,更是在濱河造成了極大的恐慌荞驴,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贯城,死亡現(xiàn)場(chǎng)離奇詭異熊楼,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)能犯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)鲫骗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人踩晶,你說(shuō)我怎么就攤上這事挎峦。” “怎么了合瓢?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵坦胶,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我晴楔,道長(zhǎng)顿苇,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任税弃,我火速辦了婚禮纪岁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘则果。我一直安慰自己幔翰,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布西壮。 她就那樣靜靜地躺著遗增,像睡著了一般。 火紅的嫁衣襯著肌膚如雪款青。 梳的紋絲不亂的頭發(fā)上做修,一...
    開(kāi)封第一講書(shū)人閱讀 49,837評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音抡草,去河邊找鬼饰及。 笑死,一個(gè)胖子當(dāng)著我的面吹牛康震,可吹牛的內(nèi)容都是我干的燎含。 我是一名探鬼主播,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼腿短,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼屏箍!你這毒婦竟也來(lái)了绘梦?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤铣除,失蹤者是張志新(化名)和其女友劉穎谚咬,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體尚粘,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡择卦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了郎嫁。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秉继。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖泽铛,靈堂內(nèi)的尸體忽然破棺而出尚辑,到底是詐尸還是另有隱情,我是刑警寧澤盔腔,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布杠茬,位于F島的核電站,受9級(jí)特大地震影響弛随,放射性物質(zhì)發(fā)生泄漏瓢喉。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一舀透、第九天 我趴在偏房一處隱蔽的房頂上張望栓票。 院中可真熱鬧,春花似錦愕够、人聲如沸走贪。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)坠狡。三九已至,卻和暖如春强衡,著一層夾襖步出監(jiān)牢的瞬間擦秽,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工漩勤, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人缩搅。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓越败,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親硼瓣。 傳聞我的和親對(duì)象是個(gè)殘疾皇子究飞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容