python判斷單向鏈表是否包括環(huán),若包含則計(jì)算環(huán)入口的節(jié)點(diǎn)實(shí)例分析
本文實(shí)例講述了python判斷單向鏈表是否包括環(huán),若包含則計(jì)算環(huán)入口的節(jié)點(diǎn)。分享給大家供大家參考,具體如下:
關(guān)于數(shù)據(jù)結(jié)構(gòu)相關(guān)的面試題,經(jīng)常會問到鏈表中是否存在環(huán)結(jié)構(gòu)的判斷,下圖就是存在環(huán)結(jié)構(gòu)的鏈表。
那么如何判斷鏈表中是否存在環(huán)呢,下面解法的思路是采用快慢指針:
兩個(gè)指向頭節(jié)點(diǎn)的指針,fast和slow,一起從頭結(jié)點(diǎn)開始往后遍歷,fast每次移動兩個(gè)節(jié)點(diǎn),slow每次移動一個(gè)節(jié)點(diǎn),
這樣,如果存在環(huán)結(jié)構(gòu),那么fast指針在不斷繞環(huán)過程中,肯定會追上slow指針。
# -*- coding:utf-8 -*- ''' Created on 2019年10月23日 @author: Administrator ''' class Node(): #定義一個(gè)Node類,構(gòu)造兩個(gè)屬性,一個(gè)是item節(jié)點(diǎn)值,一個(gè)是節(jié)點(diǎn)的下一個(gè)指向 def __init__(self,item=None): self.item = item self.next = None def findbeginofloop(head):#判斷是否為環(huán)結(jié)構(gòu)并且查找環(huán)結(jié)構(gòu)的入口節(jié)點(diǎn) slowPtr = head #將頭節(jié)點(diǎn)賦予slowPtr fastPtr = head #將頭節(jié)點(diǎn)賦予fastPtr loopExist =False #默認(rèn)環(huán)不存在,為False if head == None: #如果頭節(jié)點(diǎn)就是空的,那肯定就不存在環(huán)結(jié)構(gòu) return False while fastPtr.next != None and fastPtr.next.next != None: #fastPtr的下一個(gè)節(jié)點(diǎn)和下下個(gè)節(jié)點(diǎn)都不為空 slowPtr = slowPtr.next #slowPtr每次移動一個(gè)節(jié)點(diǎn) fastPtr = fastPtr.next.next #fastPtr每次移動兩個(gè)節(jié)點(diǎn) if slowPtr == fastPtr : #當(dāng)fastPtr和slowPtr的節(jié)點(diǎn)相同時(shí),也就是兩個(gè)指針相遇了 loopExist = True print("存在環(huán)結(jié)構(gòu)") break if loopExist == True: slowPtr = head while slowPtr != fastPtr: fastPtr = fastPtr.next slowPtr = slowPtr.next return slowPtr print("不是環(huán)結(jié)構(gòu)") return False if __name__ == "__main__": node1 = Node(1) node2 = Node(2) node3 = Node(3) node4 = Node(4) node5 = Node(5) node1.next = node2 node2.next = node3 node3.next = node4 node4.next = node5 node5.next = node2 print(findbeginofloop(node1).item)
運(yùn)行結(jié)果:
存在環(huán)結(jié)構(gòu)
2
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計(jì)有所幫助。
- python中的單向鏈表實(shí)現(xiàn)
- python如何實(shí)現(xiàn)單向鏈表及單向鏈表的反轉(zhuǎn)
- python單向鏈表的基本實(shí)現(xiàn)與使用方法【定義、遍歷、添加、刪除、查找等】
- python實(shí)現(xiàn)獲取單向鏈表倒數(shù)第k個(gè)結(jié)點(diǎn)的值示例
- python實(shí)現(xiàn)反轉(zhuǎn)部分單向鏈表
- Python單向鏈表和雙向鏈表原理與用法實(shí)例詳解
- python實(shí)現(xiàn)單向鏈表詳解
- python數(shù)據(jù)結(jié)構(gòu)鏈表之單向鏈表(實(shí)例講解)
- 淺談Python單向鏈表的實(shí)現(xiàn)
- Python實(shí)現(xiàn)單向鏈表
相關(guān)文章
Django 1.10以上版本 url 配置注意事項(xiàng)詳解
這篇文章主要介紹了Django 1.10以上版本 url 配置注意事項(xiàng)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08基于Python實(shí)現(xiàn)的ID3決策樹功能示例
這篇文章主要介紹了基于Python實(shí)現(xiàn)的ID3決策樹功能,簡單描述了ID3決策樹的相關(guān)概念,并結(jié)合實(shí)例形式分析了Python實(shí)現(xiàn)ID3決策樹的具體定義與使用技巧,需要的朋友可以參考下2018-01-01Python中TypeError:unhashable?type:'dict'錯(cuò)誤的解決辦法
這篇文章主要給大家介紹了關(guān)于Python中TypeError:unhashable?type:'dict'錯(cuò)誤的解決辦法,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-04-04Python壓縮模塊zipfile實(shí)現(xiàn)原理及用法解析
這篇文章主要介紹了Python壓縮模塊zipfile實(shí)現(xiàn)原理及用法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08python 模擬網(wǎng)站登錄——滑塊驗(yàn)證碼的識別
這篇文章主要介紹了python 模擬網(wǎng)站登錄——滑塊驗(yàn)證碼的識別,幫助大家更好的理解和學(xué)習(xí)使用python的爬蟲技術(shù),感興趣的朋友可以了解下2021-03-03python3 如何使用 goto 跳轉(zhuǎn)執(zhí)行到指定代碼行
這篇文章主要介紹了python3 使用goto跳轉(zhuǎn)執(zhí)行到指定代碼行的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05