亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python判斷單向鏈表是否包括環(huán),若包含則計算環(huán)入口的節(jié)點實例分析

 更新時間:2019年10月23日 11:48:50   作者:鯨落丶  
這篇文章主要介紹了python判斷單向鏈表是否包括環(huán),若包含則計算環(huán)入口的節(jié)點,結合實例形式分析了Python針對單向鏈表的遍歷、判斷相關算法原理與使用技巧,需要的朋友可以參考下

本文實例講述了python判斷單向鏈表是否包括環(huán),若包含則計算環(huán)入口的節(jié)點。分享給大家供大家參考,具體如下:

關于數(shù)據(jù)結構相關的面試題,經(jīng)常會問到鏈表中是否存在環(huán)結構的判斷,下圖就是存在環(huán)結構的鏈表。

那么如何判斷鏈表中是否存在環(huán)呢,下面解法的思路是采用快慢指針:

兩個指向頭節(jié)點的指針,fast和slow,一起從頭結點開始往后遍歷,fast每次移動兩個節(jié)點,slow每次移動一個節(jié)點,

這樣,如果存在環(huán)結構,那么fast指針在不斷繞環(huán)過程中,肯定會追上slow指針。

# -*- coding:utf-8 -*-
'''
Created on 2019年10月23日
@author: Administrator
'''
class Node(): #定義一個Node類,構造兩個屬性,一個是item節(jié)點值,一個是節(jié)點的下一個指向
  def __init__(self,item=None):
    self.item = item
    self.next = None
def findbeginofloop(head):#判斷是否為環(huán)結構并且查找環(huán)結構的入口節(jié)點
  slowPtr = head     #將頭節(jié)點賦予slowPtr
  fastPtr = head     #將頭節(jié)點賦予fastPtr
  loopExist =False    #默認環(huán)不存在,為False
  if head == None:    #如果頭節(jié)點就是空的,那肯定就不存在環(huán)結構
    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)結構")
      break
  if loopExist == True:
    slowPtr = head
    while slowPtr != fastPtr:
      fastPtr = fastPtr.next
      slowPtr = slowPtr.next
    return slowPtr
  print("不是環(huán)結構")
  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)

運行結果:

存在環(huán)結構
2

更多關于Python相關內容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結構與算法教程》、《Python加密解密算法與技巧總結》、《Python編碼操作技巧總結》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經(jīng)典教程

希望本文所述對大家Python程序設計有所幫助。

相關文章

  • 手把手教你Python抓取數(shù)據(jù)并可視化

    手把手教你Python抓取數(shù)據(jù)并可視化

    很多小伙伴在提到python數(shù)據(jù)可視化的時候第一反應就是matplotlib庫,但實際上python還有很多很好用的數(shù)據(jù)可視化的庫,下面這篇文章主要給大家介紹了關于如何利用Python抓取數(shù)據(jù)并可視化的相關資料,需要的朋友可以參考下
    2022-05-05
  • Django 1.10以上版本 url 配置注意事項詳解

    Django 1.10以上版本 url 配置注意事項詳解

    這篇文章主要介紹了Django 1.10以上版本 url 配置注意事項詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • 基于Python實現(xiàn)的ID3決策樹功能示例

    基于Python實現(xiàn)的ID3決策樹功能示例

    這篇文章主要介紹了基于Python實現(xiàn)的ID3決策樹功能,簡單描述了ID3決策樹的相關概念,并結合實例形式分析了Python實現(xiàn)ID3決策樹的具體定義與使用技巧,需要的朋友可以參考下
    2018-01-01
  • 常見Python AutoEDA工具庫及功能使用探究

    常見Python AutoEDA工具庫及功能使用探究

    AutoEDA(自動探索性數(shù)據(jù)分析)工具庫是數(shù)據(jù)科學中至關重要的一部分,它們能夠自動生成數(shù)據(jù)摘要、探查數(shù)據(jù)的基本特征、檢測異常值和提供可視化,為數(shù)據(jù)科學家和分析師們提供了解數(shù)據(jù)的便捷方式,本文為大家介紹常見的AutoEDA工具庫及其功能和示例代碼
    2024-01-01
  • Python中TypeError:unhashable?type:'dict'錯誤的解決辦法

    Python中TypeError:unhashable?type:'dict'錯誤的解決辦法

    這篇文章主要給大家介紹了關于Python中TypeError:unhashable?type:'dict'錯誤的解決辦法,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2023-04-04
  • Python壓縮模塊zipfile實現(xiàn)原理及用法解析

    Python壓縮模塊zipfile實現(xiàn)原理及用法解析

    這篇文章主要介紹了Python壓縮模塊zipfile實現(xiàn)原理及用法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-08-08
  • 詳解python文件的操作和異常的處理

    詳解python文件的操作和異常的處理

    這篇文章主要為大家介紹了python文件的操作和異常的處理,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • python 模擬網(wǎng)站登錄——滑塊驗證碼的識別

    python 模擬網(wǎng)站登錄——滑塊驗證碼的識別

    這篇文章主要介紹了python 模擬網(wǎng)站登錄——滑塊驗證碼的識別,幫助大家更好的理解和學習使用python的爬蟲技術,感興趣的朋友可以了解下
    2021-03-03
  • python3 如何使用 goto 跳轉執(zhí)行到指定代碼行

    python3 如何使用 goto 跳轉執(zhí)行到指定代碼行

    這篇文章主要介紹了python3 使用goto跳轉執(zhí)行到指定代碼行的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python編程實現(xiàn)蟻群算法詳解

    Python編程實現(xiàn)蟻群算法詳解

    這篇文章主要介紹了Python編程實現(xiàn)蟻群算法詳解,涉及螞蟻算法的簡介,主要原理及公式,以及Python中的實現(xiàn)代碼,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11

最新評論