码迷,mamicode.com
首页 > 编程语言 > 详细

python数据结构与算法(9)

时间:2018-11-28 13:14:08      阅读:223      评论:0      收藏:0      [点我收藏+]

标签:arc   empty   遍历   remove   roc   变形   分享   shadow   lin   

指定位置插?节点
技术分享图片

def insert(self,    pos,    item):                              """在指定位置添加节点"""                             if  pos <=   0:                                              self.add(item)                              elif    pos >    (self.length()-1):                                              self.append(item)                               else:                                               node    =   Node(item)                                              cur =   self.__head                                             count   =   0                                               #   移动到指定位置的前?个位置                                               while   count   <    (pos-1):                                                                count   +=  1                                                               cur =   cur.next                                                #   将node的prev指向cur                                             node.prev   =   cur                                             #   将node的next指向cur的下?个节点                                               node.next   =   cur.next                                                #   将cur的下?个节点的prev指向node                                               cur.next.prev   =   node                                                #   将cur的next指向node                                             cur.next    =   node

删除元素

技术分享图片

def remove(self, item): """删除元素""" cur = self.__head while cur != None: # 找到了要删除的元素 if cur.item == item: # 先判断此结点是否是头节点 # 头节点 if cur == self.__head: self.__head = cur.next # 如果存在下?个结点,则设置下?个结点 if cur.next: # 判断链表是否只有?个结点 cur.next.prev = None else: cur.prev.next = cur.next # 如果存在下?个结点,则设置下?个结点 if cur.next: cur.next.prev = cur.prev break else: cur = cur.next

测试


if  __name__    ==  "__main__":             ll  =   DLinkList()             ll.add(1)               ll.add(2)               ll.append(3)
ll.insert(2,    4)              ll.insert(4,    5)              ll.insert(0,    6)              print   "length:",ll.length()               ll.travel()             print   ll.search(3)                print   ll.search(4)                ll.remove(1)                print   "length:",ll.length()
    ll.travel()

单向循环链表
单链表的?个变形是单向循环链表,链表中最后?个节点的next域不再为 None,?是指向链表的头节点。

技术分享图片
操作
is_empty() 判断链表是否为空 length() 返回链表的?度 travel() 遍历 add(item) 在头部添加?个节点 append(item) 在尾部添加?个节点 insert(pos, item) 在指定位置pos添加节点 remove(item) 删除?个节点 search(item) 查找节点是否存在
实现

class   Node(object):               """节点"""                def __init__(self,  item):                              self.item   =   item                                self.next   =   None
class   SinCycLinkedlist(object):               """单向循环链表"""                def __init__(self):                             self.__head =   None
    def is_empty(self):                             """判断链表是否为空"""                              return  self.__head ==  None
                def length(self):                               """返回链表的?度"""                               #   如果链表为空,返回?度0                                if  self.is_empty():                                                return  0                               count   =   1                               cur =   self.__head                             while   cur.next    !=  self.__head:                                                count   +=  1                                               cur =   cur.next                                return  count
                def travel(self):                               """遍历链表"""                              if  self.is_empty():                                                return                              cur =   self.__head                             print   cur.item,                               while   cur.next    !=  self.__head:                                                cur =   cur.next                                                print   cur.item,                               print   ""
                def add(self,   item):                              """头部添加节点"""                                node    =   Node(item)                              if  self.is_empty():                                                self.__head =   node                                                node.next   =   self.__head                             else:                                               #添加的节点指向_head                                               node.next   =   self.__head #   移到链表尾部,将尾部节点的next指向node                                             cur =   self.__head                                             while   cur.next    !=  self.__head:                                                                cur =   cur.next                                                cur.next    =   node                                                #_head指向添加node的                                             self.__head =   node
                def append(self,    item):                              """尾部添加节点"""                                node    =   Node(item)                              if  self.is_empty():                                                self.__head =   node                                                node.next   =   self.__head                             else:                                               #   移到链表尾部                                              cur =   self.__head                                             while   cur.next    !=  self.__head:                                                                cur =   cur.next                                                #   将尾节点指向node                                              cur.next    =   node                                                #   将node指向头节点_head                                             node.next   =   self.__head
                def insert(self,    pos,    item):                              """在指定位置添加节点"""                             if  pos <=   0:                                              self.add(item)                              elif    pos >    (self.length()-1):                                              self.append(item)                               else:                                               node    =   Node(item)                                              cur =   self.__head                                             count   =   0                                               #   移动到指定位置的前?个位置                                               while   count   <    (pos-1):                                                                count   +=  1                                                               cur =   cur.next
    node.next   =   cur.next                                                cur.next    =   node
                def remove(self,    item):                              """删除?个节点"""                                #   若链表为空,则直接返回                             if  self.is_empty():                                                return                              #   将cur指向头节点                               cur =   self.__head                             pre =   None                                while   cur.next    !=  self.__head:                                                if  cur.item    ==  item:                                                               #   先判断此结点是否是头节点                                                                if  cur ==  self.__head:                                                                                #   头节点的情况                                                                              #   找尾节点                                                                                rear    =   self.__head                                                                             while   rear.next   !=  self.__head:                                                                                                rear    =   rear.next                                                                               self.__head =   cur.next                                                                                rear.next   =   self.__head                                                             else:                                                                               #   中间节点                                                                                pre.next    =   cur.next                                                                return                                              else:                                                               pre =   cur                                                             cur =   cur.next                                #   退出循环,cur指向尾节点                               if  cur.item    ==  item:                                               if  cur ==  self.__head:                                                                #   链表只有?个节点                                                                self.__head =   None                                                else:                                                               #   pre.next    =   cur.next                                                                pre.next    =   self.__head
    def search(self,    item):                              """查找节点是否存在"""                              if  self.is_empty():                                                return  False                               cur =   self.__head                             if  cur.item    ==  item:                                               return  True                                while   cur.next    !=  self.__head:                                                cur =   cur.next                                                if  cur.item    ==  item:                                                               return  True                                return  False
if  __name__    ==  "__main__":             ll  =   SinCycLinkedlist()              ll.add(1)               ll.add(2)               ll.append(3)                ll.insert(2,    4)              ll.insert(4,    5)              ll.insert(0,    6)              print   "length:",ll.length()               ll.travel()             print   ll.search(3)                print   ll.search(7)                ll.remove(1)                print   "length:",ll.length()               ll.travel()

python数据结构与算法(9)

标签:arc   empty   遍历   remove   roc   变形   分享   shadow   lin   

原文地址:http://blog.51cto.com/13517854/2323070

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!