欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python數(shù)據(jù)結(jié)構(gòu)鏈表之單向鏈表(實(shí)例講解)

 更新時(shí)間:2017年07月25日 08:33:35   投稿:jingxian  
下面小編就為大家?guī)硪黄猵ython數(shù)據(jù)結(jié)構(gòu)鏈表之單向鏈表(實(shí)例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

單向鏈表

單向鏈表也叫單鏈表,是鏈表中最簡單的一種形式,它的每個(gè)節(jié)點(diǎn)包含兩個(gè)域,一個(gè)信息域(元素域)和一個(gè)鏈接域。這個(gè)鏈接指向鏈表中的下一個(gè)節(jié)點(diǎn),而最后一個(gè)節(jié)點(diǎn)的鏈接域則指向一個(gè)空值。

表元素域elem用來存放具體的數(shù)據(jù)。

鏈接域next用來存放下一個(gè)節(jié)點(diǎn)的位置(python中的標(biāo)識(shí))

變量p指向鏈表的頭節(jié)點(diǎn)(首節(jié)點(diǎn))的位置,從p出發(fā)能找到表中的任意節(jié)點(diǎn)。

節(jié)點(diǎn)實(shí)現(xiàn)

class Node(object):
 """單鏈表的結(jié)點(diǎn)"""
 def __init__(self,item):
  # item存放數(shù)據(jù)元素
  self.item = item
  # next是下一個(gè)節(jié)點(diǎn)的標(biāo)識(shí)
  self.next = None

單鏈表的操作

is_empty() 鏈表是否為空

length() 鏈表長度

travel() 遍歷整個(gè)鏈表

add(item) 鏈表頭部添加元素

append(item) 鏈表尾部添加元素

insert(pos, item) 指定位置添加元素

remove(item) 刪除節(jié)點(diǎn)

search(item) 查找節(jié)點(diǎn)是否存在

單鏈表的實(shí)現(xiàn)

class Singlepnkpst(object):
 """單鏈表"""
 def __init__(self):
  self.__head = None
 
 def is_empty(self):
  """判斷鏈表是否為空"""
  return self.__head == None
 
 def length(self):
  """鏈表長度"""
  # cur初始時(shí)指向頭節(jié)點(diǎn)
  cur = self.__head
  count = 0
  # 尾節(jié)點(diǎn)指向None,當(dāng)未到達(dá)尾部時(shí)
  while cur != None:
   count += 1
   # 將cur后移一個(gè)節(jié)點(diǎn)
   cur = cur.next
  return count
 
 def travel(self):
  """遍歷鏈表"""
  cur = self.__head
  while cur != None:
   print(cur.item,end = ' ')
   cur = cur.next
  print("")

頭部添加元素

def add(self, item):
  """頭部添加元素"""
  # 先創(chuàng)建一個(gè)保存item值的節(jié)點(diǎn)
  node = Node(item)
  # 將新節(jié)點(diǎn)的鏈接域next指向頭節(jié)點(diǎn),即_head指向的位置
  node.next = self.__head
  # 將鏈表的頭_head指向新節(jié)點(diǎn)
  self.__head = nod

尾部添加元素

def append(self, item):
  """尾部添加元素"""
  node = Node(item)
  # 先判斷鏈表是否為空,若是空鏈表,則將_head指向新節(jié)點(diǎn)
  if self.is_empty():
    self.__head = node
  # 若不為空,則找到尾部,將尾節(jié)點(diǎn)的next指向新節(jié)點(diǎn)
  else:
    cur = self.__head
    while cur.next != None:
      cur = cur.next
    cur.next = node

指定位置添加元素

def insert(self, pos, item):
  """指定位置添加元素"""
  # 若指定位置pos為第一個(gè)元素之前,則執(zhí)行頭部插入
  if pos <= 0:
   self.add(item)
  # 若指定位置超過鏈表尾部,則執(zhí)行尾部插入
  epf pos > (self.length()-1):
   self.append(item)
  # 找到指定位置
  else:
    node = Node(item)
    count = 0
    # pre用來指向指定位置pos的前一個(gè)位置pos-1,初始從頭節(jié)點(diǎn)開始移動(dòng)到指定位置
    pre = self.__head
    while count < (pos-1):
      count += 1
      pre = pre.next
    # 先將新節(jié)點(diǎn)node的next指向插入位置的節(jié)點(diǎn)
    node.next = pre.next
    # 將插入位置的前一個(gè)節(jié)點(diǎn)的next指向新節(jié)點(diǎn)
    pre.next = node

刪除節(jié)點(diǎn)

def remove(self,item):
  """刪除節(jié)點(diǎn)"""
  cur = self.__head
  pre = None
  while cur != None:
  # 找到了指定元素
  if cur.item == item:
    # 如果第一個(gè)就是刪除的節(jié)點(diǎn)
    if not pre:
      # 將頭指針指向頭節(jié)點(diǎn)的后一個(gè)節(jié)點(diǎn)
      self.__head = cur.next
    else:
      # 將刪除位置前一個(gè)節(jié)點(diǎn)的next指向刪除位置的后一個(gè)節(jié)點(diǎn)
      pre.next = cur.next
      break
    else:
      # 繼續(xù)按鏈表后移節(jié)點(diǎn)
      pre = cur
      cur = cur.next

查找節(jié)點(diǎn)是否存在

def search(self,item):
  """鏈表查找節(jié)點(diǎn)是否存在,并返回True或者False"""
  cur = self.__head
  while cur != None:
    if cur.item == item:
      return True
      cur = cur.next
    return False

以上這篇python數(shù)據(jù)結(jié)構(gòu)鏈表之單向鏈表(實(shí)例講解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • python和shell監(jiān)控linux服務(wù)器的詳細(xì)代碼

    python和shell監(jiān)控linux服務(wù)器的詳細(xì)代碼

    這篇文章主要為大家介紹了使用python和shell監(jiān)控linux服務(wù)器的詳細(xì)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • python通過exifread模塊獲得圖片exif信息的方法

    python通過exifread模塊獲得圖片exif信息的方法

    這篇文章主要介紹了python通過exifread模塊獲得圖片exif信息的方法,實(shí)例分析了Python操作exifread模塊的技巧,需要的朋友可以參考下
    2015-03-03
  • python-numpy-指數(shù)分布實(shí)例詳解

    python-numpy-指數(shù)分布實(shí)例詳解

    今天小編就為大家分享一篇python-numpy-指數(shù)分布實(shí)例詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • Python?Timer和TimerFPS計(jì)時(shí)工具類

    Python?Timer和TimerFPS計(jì)時(shí)工具類

    這篇文章主要介紹了Python?Timer和TimerFPS計(jì)時(shí)工具類,文章分享得代碼內(nèi)容詳細(xì),具有一的的參考價(jià)值,需要的小伙伴可以參考一下
    2022-03-03
  • Python實(shí)現(xiàn)智慧校園自動(dòng)評(píng)教全新版

    Python實(shí)現(xiàn)智慧校園自動(dòng)評(píng)教全新版

    上一次的智慧校園自動(dòng)評(píng)教是用的selenium庫去模擬人去對(duì)瀏覽器進(jìn)行點(diǎn)擊操作,雖然比手動(dòng)評(píng)教要快,但是效率還是不高.從而想去嘗試重新寫一份不用selenium的評(píng)教方案,功夫不負(fù)有心人,最終成功了,需要的朋友可以參考下
    2021-06-06
  • python如何處理程序無法打開

    python如何處理程序無法打開

    在本篇文章里小編給大家整理是一篇關(guān)于python解決程序無法打開的相關(guān)文章內(nèi)容,需要的朋友們可以學(xué)習(xí)下。
    2020-06-06
  • tensorflow: 查看 tensor詳細(xì)數(shù)值方法

    tensorflow: 查看 tensor詳細(xì)數(shù)值方法

    今天小編就為大家分享一篇tensorflow: 查看 tensor詳細(xì)數(shù)值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-06-06
  • python簡單的三元一次方程求解實(shí)例

    python簡單的三元一次方程求解實(shí)例

    這篇文章主要介紹了python簡單的三元一次方程求解實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 詳解利用python+opencv識(shí)別圖片中的圓形(霍夫變換)

    詳解利用python+opencv識(shí)別圖片中的圓形(霍夫變換)

    這篇文章主要介紹了詳解利用python+opencv識(shí)別圖片中的圓形(霍夫變換),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Python中使用zip函數(shù)的七重境界解析

    Python中使用zip函數(shù)的七重境界解析

    這篇文章主要介紹了Python中使用zip函數(shù)的七重境界,重點(diǎn)介紹了Python中功能強(qiáng)大的zip 函數(shù)的多種用法,并給出了相應(yīng)的代碼示例,需要的朋友可以參考下
    2022-12-12

最新評(píng)論