python判斷單向鏈表是否包括環(huán),若包含則計算環(huán)入口的節(jié)點實例分析
本文實例講述了python判斷單向鏈表是否包括環(huán),若包含則計算環(huán)入口的節(jié)點。分享給大家供大家參考,具體如下:
關(guān)于數(shù)據(jù)結(jié)構(gòu)相關(guān)的面試題,經(jīng)常會問到鏈表中是否存在環(huán)結(jié)構(gòu)的判斷,下圖就是存在環(huán)結(jié)構(gòu)的鏈表。

那么如何判斷鏈表中是否存在環(huán)呢,下面解法的思路是采用快慢指針:
兩個指向頭節(jié)點的指針,fast和slow,一起從頭結(jié)點開始往后遍歷,fast每次移動兩個節(jié)點,slow每次移動一個節(jié)點,
這樣,如果存在環(huán)結(jié)構(gòu),那么fast指針在不斷繞環(huán)過程中,肯定會追上slow指針。
# -*- coding:utf-8 -*-
'''
Created on 2019年10月23日
@author: Administrator
'''
class Node(): #定義一個Node類,構(gòu)造兩個屬性,一個是item節(jié)點值,一個是節(jié)點的下一個指向
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é)點
slowPtr = head #將頭節(jié)點賦予slowPtr
fastPtr = head #將頭節(jié)點賦予fastPtr
loopExist =False #默認環(huán)不存在,為False
if head == None: #如果頭節(jié)點就是空的,那肯定就不存在環(huán)結(jié)構(gòu)
return False
while fastPtr.next != None and fastPtr.next.next != None: #fastPtr的下一個節(jié)點和下下個節(jié)點都不為空
slowPtr = slowPtr.next #slowPtr每次移動一個節(jié)點
fastPtr = fastPtr.next.next #fastPtr每次移動兩個節(jié)點
if slowPtr == fastPtr : #當fastPtr和slowPtr的節(jié)點相同時,也就是兩個指針相遇了
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)
運行結(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īng)典教程》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
Python matplotlib 繪制雙Y軸曲線圖的示例代碼
Matplotlib是非常強大的python畫圖工具,這篇文章主要介紹了Python matplotlib 繪制雙Y軸曲線圖,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06
python?裝飾器(Decorators)原理說明及操作代碼
裝飾器(Decorators)是 Python 的一個重要部分,本文由淺入深給大家介紹了python?裝飾器Decorators原理,感興趣的朋友跟隨小編一起看看吧2021-12-12
基于Python編寫簡單的網(wǎng)絡(luò)測試工具
這篇文章主要為大家詳細介紹了如何基于Python編寫一個簡單的網(wǎng)絡(luò)測試工具,可以測試網(wǎng)絡(luò)的下載速度,上傳速度和延遲,感興趣的可以了解下2025-02-02
使用Python實現(xiàn)搖號系統(tǒng)的詳細步驟
這篇文章主要介紹了如何使用Python構(gòu)建一個簡單的搖號系統(tǒng),包括需求分析、技術(shù)棧、實現(xiàn)步驟和完整代碼示例,該系統(tǒng)能夠從用戶輸入的參與者名單中隨機抽取指定數(shù)量的中獎者,并將結(jié)果展示給用戶以及記錄到日志文件中,需要的朋友可以參考下2024-11-11
pycharm配置python 設(shè)置pip安裝源為豆瓣源
這篇文章主要介紹了pycharm配置python 設(shè)置pip安裝源為豆瓣源,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02

