国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - 淺談Python單向鏈表的實現

淺談Python單向鏈表的實現

2020-08-05 09:35腳本之家 Python

本文給大家簡單介紹了下鏈表的知識,然后用Python模擬一下單鏈表,比較簡單,初學者可以參考參考,大神可以給我點改進意見

鏈表由一系列不必在內存中相連的結構構成,這些對象按線性順序排序。每個結構含有表元素和指向后繼元素的指針。最后一個單元的指針指向NULL。為了方便鏈表的刪除與插入操作,可以為鏈表添加一個表頭。

淺談Python單向鏈表的實現

刪除操作可以通過修改一個指針來實現。

淺談Python單向鏈表的實現

插入操作需要執行兩次指針調整。

淺談Python單向鏈表的實現

1. 單向鏈表的實現

1.1 Node實現

    每個Node分為兩部分。一部分含有鏈表的元素,可以稱為數據域;另一部分為一指針,指向下一個Node。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
class Node():
  __slots__=['_item','_next'#限定Node實例的屬性
  def __init__(self,item):
    self._item=item
    self._next=None   #Node的指針部分默認指向None
  def getItem(self):
    return self._item
  def getNext(self):
    return self._next
  def setItem(self,newitem):
    self._item=newitem
  def setNext(self,newnext):
    self._next=newnext

1.2 SinglelinkedList的實現

?
1
2
3
4
class SingleLinkedList():
  def __init__(self):
    self._head=None  #初始化鏈表為空表
    self._size=0

1.3 檢測鏈表是否為空

?
1
2
def isEmpty(self):
  return self._head==None

1.4 add在鏈表前端添加元素

?
1
2
3
4
def add(self,item):
  temp=Node(item)
  temp.setNext(self._head)
  self._head=temp

1.5 append在鏈表尾部添加元素

?
1
2
3
4
5
6
7
8
9
10
def append(self,item):
  temp=Node(item)
  if self.isEmpty():
    self._head=temp  #若為空表,將添加的元素設為第一個元素
  else:
    current=self._head
    while current.getNext()!=None:
      current=current.getNext()  #遍歷鏈表
    current.setNext(temp)  #此時current為鏈表最后的元素
 

1.6 search檢索元素是否在鏈表中

?
1
2
3
4
5
6
7
8
9
def search(self,item):
  current=self._head
  founditem=False
  while current!=None and not founditem:
    if current.getItem()==item:
      founditem=True
    else:
      current=current.getNext()
  return founditem

1.7 index索引元素在鏈表中的位置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
def index(self,item):
  current=self._head
  count=0
  found=None
  while current!=None and not found:
    count+=1
    if current.getItem()==item:
      found=True
    else:
      current=current.getNext()
  if found:
    return count
  else:
    raise ValueError,'%s is not in linkedlist'%item

1.8 remove刪除鏈表中的某項元素

?
1
2
3
4
5
6
7
8
9
10
11
12
13
def remove(self,item):
  current=self._head
  pre=None
  while current!=None:
    if current.getItem()==item:
      if not pre:
        self._head=current.getNext()
      else:
        pre.setNext(current.getNext())
      break
    else:
      pre=current
      current=current.getNext()

1.9 insert鏈表中插入元素

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def insert(self,pos,item):
  if pos<=1:
    self.add(item)
  elif pos>self.size():
    self.append(item)
  else:
    temp=Node(item)
    count=1
    pre=None
    current=self._head
    while count<pos:
      count+=1
      pre=current
      current=current.getNext()
    pre.setNext(temp)
    temp.setNext(current)

全部代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
class Node():
  __slots__=['_item','_next']
  def __init__(self,item):
    self._item=item
    self._next=None
  def getItem(self):
    return self._item
  def getNext(self):
    return self._next
  def setItem(self,newitem):
    self._item=newitem
  def setNext(self,newnext):
    self._next=newnext
     
class SingleLinkedList():
  def __init__(self):
    self._head=None #初始化為空鏈表
  def isEmpty(self):
    return self._head==None
  def size(self):
    current=self._head
    count=0
    while current!=None:
      count+=1
      current=current.getNext()
    return count
  def travel(self):
    current=self._head
    while current!=None:
      print current.getItem()
      current=current.getNext()
  def add(self,item):
    temp=Node(item)
    temp.setNext(self._head)
    self._head=temp
 
  def append(self,item):
    temp=Node(item)
    if self.isEmpty():
      self._head=temp  #若為空表,將添加的元素設為第一個元素
    else:
      current=self._head
      while current.getNext()!=None:
        current=current.getNext()  #遍歷鏈表
      current.setNext(temp)  #此時current為鏈表最后的元素
  def search(self,item):
    current=self._head
    founditem=False
    while current!=None and not founditem:
      if current.getItem()==item:
        founditem=True
      else:
        current=current.getNext()
    return founditem
  def index(self,item):
    current=self._head
    count=0
    found=None
    while current!=None and not found:
      count+=1
      if current.getItem()==item:
        found=True
      else:
        current=current.getNext()
    if found:
      return count
    else:
      raise ValueError,'%s is not in linkedlist'%item      
  def remove(self,item):
    current=self._head
    pre=None
    while current!=None:
      if current.getItem()==item:
        if not pre:
          self._head=current.getNext()
        else:
          pre.setNext(current.getNext())
        break
      else:
        pre=current
        current=current.getNext()          
  def insert(self,pos,item):
    if pos<=1:
      self.add(item)
    elif pos>self.size():
      self.append(item)
    else:
      temp=Node(item)
      count=1
      pre=None
      current=self._head
      while count<pos:
        count+=1
        pre=current
        current=current.getNext()
      pre.setNext(temp)
      temp.setNext(current)
 
if __name__=='__main__':
  a=SingleLinkedList()
  for i in range(1,10):
    a.append(i)
  print a.size()
  a.travel()
  print a.search(6)
  print a.index(5)
  a.remove(4)
  a.travel()
  a.insert(4,100)
  a.travel()

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 四虎av成人 | 国产成人一区二区啪在线观看 | 成人a毛片 | 中国黄色三级毛片 | 99热69 | 亚洲专区国产精品 | jvid精品资源在线观看 | 亚洲一区av在线 | 久久黄网站 | 毛片在线一区二区观看精品 | yellow视频在线 | 免费午夜电影 | 色婷婷国产精品免费网站 | 日韩高清一区 | 成年人免费观看在线视频 | 国产区在线观看 | 免费成人av片 | 黄色免费视频在线观看 | 国产96在线视频 | 精品久草 | 欧美国产视频 | 国产成人精品一区二区三区四区 | 日韩在线观看一区二区 | 天天躁日日躁bbbbb | 成人在线午夜 | 久久午夜精品 | 日本不卡一区二区三区在线观看 | 欧美一区二区黄 | 一大道一二三区不卡 | 免费污污视频在线观看 | 欧美99 | 日韩中文字幕在线播放 | 操操操操操操操 | 久久99精 | 亚洲国产中文字幕 | 69国产精品成人96视频色 | 日韩欧美一区二区三区免费观看 | 一级毛片久久久 | 国产成年人电影在线观看 | 欧美黄视频 | 国产精品第一国产精品 |