Python—数据结构——链表

数据结构——链表

一.简介  

  链表是一种物理存储上非连续,数据元素的逻辑顺序通过链表中的指针链接次序,实现的一种线性存储结构。由一系列节点组成的元素集合。每个节点包含两部分,
数据域item和指向下一个节点的指针next。通过节点之间的相互连接,最终串联成一个链表。
  链表中的每个节点包括两个部分:一个是存储数据元素的数据域;另一个是存储下一个节点的地址的指针域
  双向链表:双链表的每个节点有两个指针:一个指向后一个节点,另一个指向前一个节点。

二.Python实现

  ♦链表节点

class Node:
    def __init__(self, item=None):
        self.item = item
        self.next = None

  ♦单向链表

class SingleLinkedList:
    """
    单向链表
    """

    def __init__(self, heda=None):
        self._head = heda
        self.length = 0

  ♦添加节点

   头插法:从链表的头部(左端)插入                

         

    def add_head(self, element):
        """
        头插法:从头部插入
        :param element: 需要添加进去的元素
        :return:
        """
        node = Node(element)
        if self._head is None:
            self._head = node
        else:
            node.next = self._head
            self._head = node
        self.length += 1

   尾插法:从链表的尾部(右端)插入

       

    def add_tail(self, element):
        """
        尾插法:从尾部添加元素
        :param element:需要添加进去的元素
        :return:
        """
        # 创建一个节点
        node = Node(element)
        if self._head is None:
            self._head = node
        else:
            cur = self._head
            # cur=node,node.next=None
            while cur.next:
                cur = cur.next
            cur.next = node
            return cur.next
        self.length += 1

  ♦插入节点

         

    def insert(self, item: Node, index: int):
        """
        往链表中指定位置插入值
        :param item: 插入的节点
        :param index: 插入的位置
        :return:
        """
        if index < 0 or index > self.length:
            print('index out of range')
            return
        # 构建节点
        if isinstance(item, Node):
            node_insert = item
        else:
            node_insert = Node(item)
        if index == 0:
            node_insert.next = self._head
            self._head = node_insert
        else:
            # 找到index的前一个节点
            pre = self._head
            for i in range(self.length):
                if i == index - 1:
                    node_insert.next = pre.next
                    pre.next = node_insert
                    break
                pre = pre.next
        self.length += 1
        return

  ♦删除节点

          

    def delete(self, index: int):
        """
        删除指定位置的节点
        :param index: 节点的位置
        :return:
        """
        # 判空
        if self.is_empty():
            print('empty chain')
            return
        if index < 0 or index > self.length:
            print('index out of range')
            return

        if index == 0:
            self._head = self._head.next
        else:
            pre = self._head
            for i in range(self.length):
                if i == index - 1:
                    pre.next = pre.next.next
                    break
                pre = pre.next
        self.length -= 1
        return

  ♦修改节点

    def update(self, item, index: int):
        """
        修改节点item值
        :param item: 修改之后的值
        :param index:节点的位置
        :return:
        """
        # 判空
        if self.is_empty():
            print('empty chain')
            return
        if index < 0 or index >= self.length:
            print('index out of range')
            return

        node = self._head
        for i in range(self.length):
            if i == index:
                node.item = item
                return
            node = node.next

   ♦获取节点

    def get_item(self, index: int):
        """
        获取指定位置的节点item
        :param index:指定位置
        :return:item
        """
        # 判空
        if self.is_empty():
            print('empty chain')
            return
        if index < 0 or index >= self.length:
            print('index out of range')
            return

        node = self._head
        for i in range(self.length):
            if i == index:
                return node.item
            node = node.next

  ♦遍历链表

    

    def traversal(self):
        """链表遍历"""
        if self._head is None:
            return
        else:
            cur = self._head
            while cur:
                print(cur.item)
                cur = cur.next

  ♦反转链表

        

 

 

              

    def reverse(self):
        """
        单向链表的反转:Input:1>2>3>4>5
                     Output:5>4>3>2>1
        :return:
        """
        if self._head is None or self.size() == 1:
            return
        else:
            pre = None
            cur = self._head
            while cur is not None:
                post = cur.next
                cur.next = pre
                pre = cur
                cur = post
            self._head = pre            # 逆向后的头节点
            self.traversal()

  ♦双向链表

class Node:
    def __init__(self, item=None):
        self.item = item
        self.next = None
        self.prior = None

  

 

 

   ♦双链表节点删除

      

 

  ♦双链表节点插入

      

 

 

 

  1 class Node:
  2     def __init__(self, item=None):
  3         self.item = item
  4         self.next = None
  5         self.prior = None
  6 
  7 
  8 class SingleLinkedList:
  9     """
 10     单向链表
 11     """
 12 
 13     def __init__(self, heda=None):
 14         self._head = heda
 15         self.length = 0
 16 
 17     def is_empty(self):
 18         """判断是否为空"""
 19         return self.length == 0
 20 
 21     def add_tail(self, element):
 22         """
 23         尾插法:从尾部添加元素
 24         :param element:需要添加进去的元素
 25         :return:
 26         """
 27         # 创建一个节点
 28         node = Node(element)
 29         if self._head is None:
 30             self._head = node
 31         else:
 32             cur = self._head
 33             # cur=node,node.next=None
 34             while cur.next:
 35                 cur = cur.next
 36             cur.next = node
 37             return cur.next
 38         self.length += 1
 39 
 40     def add_head(self, element):
 41         """
 42         头插法:从头部插入
 43         :param element: 需要添加进去的元素
 44         :return:
 45         """
 46         node = Node(element)
 47         if self._head is None:
 48             self._head = node
 49         else:
 50             node.next = self._head
 51             self._head = node
 52         self.length += 1
 53 
 54     def size(self):
 55 
 56         """
 57         获取链表的大小
 58         :return:int
 59         """
 60         count = 0
 61         if self._head is None:
 62             return count
 63 
 64         else:
 65             cur = self._head
 66         while cur is not None:
 67             count += 1
 68             cur = cur.next
 69         return count
 70 
 71     def insert(self, item: Node, index: int):
 72         """
 73         往链表中指定位置插入值
 74         :param item: 插入的节点
 75         :param index: 插入的位置
 76         :return:
 77         """
 78         if index < 0 or index > self.length:
 79             print('index out of range')
 80             return
 81         # 构建节点
 82         if isinstance(item, Node):
 83             node_insert = item
 84         else:
 85             node_insert = Node(item)
 86         if index == 0:
 87             node_insert.next = self._head
 88             self._head = node_insert
 89         else:
 90             # 找到index的前一个节点
 91             pre = self._head
 92             for i in range(self.length):
 93                 if i == index - 1:
 94                     node_insert.next = pre.next
 95                     pre.next = node_insert
 96                     break
 97                 pre = pre.next
 98         self.length += 1
 99         return
100 
101     def delete(self, index: int):
102         """
103         删除指定位置的节点
104         :param index: 节点的位置
105         :return:
106         """
107         # 判空
108         if self.is_empty():
109             print('empty chain')
110             return
111         if index < 0 or index > self.length:
112             print('index out of range')
113             return
114 
115         if index == 0:
116             self._head = self._head.next
117         else:
118             pre = self._head
119             for i in range(self.length):
120                 if i == index - 1:
121                     pre.next = pre.next.next
122                     break
123                 pre = pre.next
124         self.length -= 1
125         return
126 
127     def update(self, item, index: int):
128         """
129         修改节点item值
130         :param item: 修改之后的值
131         :param index:节点的位置
132         :return:
133         """
134         # 判空
135         if self.is_empty():
136             print('empty chain')
137             return
138         if index < 0 or index >= self.length:
139             print('index out of range')
140             return
141 
142         node = self._head
143         for i in range(self.length):
144             if i == index:
145                 node.item = item
146                 return
147             node = node.next
148 
149     def get_item(self, index: int):
150         """
151         获取指定位置的节点item
152         :param index:指定位置
153         :return:item
154         """
155         # 判空
156         if self.is_empty():
157             print('empty chain')
158             return
159         if index < 0 or index >= self.length:
160             print('index out of range')
161             return
162 
163         node = self._head
164         for i in range(self.length):
165             if i == index:
166                 return node.item
167             node = node.next
168 
169     def traversal(self):
170         """链表遍历"""
171         if self._head is None:
172             return
173         else:
174             cur = self._head
175             while cur:
176                 print(cur.item)
177                 cur = cur.next
178 
179     def reverse(self):
180         """
181         单向链表的反转:Input:1>2>3>4>5
182                      Output:5>4>3>2>1
183         思路:先将head.next断开,即指向断开的元素pre(none);再将pre赋值head,将head赋值head.next;最后将head赋值pre
184         :return:
185         """
186         if self._head is None or self.size() == 1:
187             return
188         else:
189             pre = None
190             cur = self._head
191             while cur is not None:
192                 post = cur.next
193                 cur.next = pre
194                 pre = cur
195                 cur = post
196             self._head = pre            # 逆向后的头节点
197             self.traversal()
LinkedList

 

  

 

posted @ 2019-09-21 14:50  ZivLi  阅读(390)  评论(0编辑  收藏  举报