• 技术文章 >后端开发 >Python教程

    Python单链表的简单实现方法

    2016-06-16 08:41:47原创732
    本文实例讲述了Python单链表的简单实现方法,分享给大家供大家参考。具体方法如下:

    通常来说,要定义一个单链表,首先定义链表元素:Element.它包含3个字段:

    list:标识自己属于哪一个list
    datum:改元素的value
    next:下一个节点的位置

    具体实现代码如下:

    class LinkedList(object):
      
      class Element(object):
        
        def __init__(self,list,datum,next): 
          self._list = list
          self._datum = datum 
          self._next = next
    
        def getDatum(self): 
          return self._datum
    
        datum = property(
          fget = lambda self: self.getDatum())
    
        def getNext(self):
          return self._next
    
        next = property(
          fget = lambda self: self.getNext())
    
      def __init__(self):
    
        self._head = None
        self._tail = None
      def getHead(self):
        return self._head 
      head = property(
        fget = lambda self: self.getHead()) 
      def prepend(self,item):
        tmp = self.Element (self,item,self._head)
        if self._head is None:
          self._tail = tmp 
        self._head = tmp 
    
      def insert(self, pos, item):
        i = 0
        p = self._head
        while p != None and i < pos -1:
          p = p._next
          i += 1
        if p == None or i > pos-1:
          return -1
        tmp = self.Element(self, item, p._next)
        p._next = tmp
        return 1
      def getItem(self, pos):
        i = 0
        p = self._head
        while p != None and i < pos -1:
          p = p._next
          i += 1
        if p == None or i > post-1:
          return -1
        return p._datum
      def delete(self, pos):
        i = 0
        p = self._head
        while p != None and i < pos -1:
          p = p._next
          i += 1
        if p == None or i > post-1:
          return -1
        q = p._next
        p._nex = q._next
        datum = p._datum
        return datum
      def setItem(self, pos, item):
        i = 0
        p = self._head
        while p != None and i < pos -1:
          p = p._next
          i += 1
        if p == None or i > post-1:
          return -1
        p._datum = item
        return 1
      def find(self, pos, item):
        i = 0
        p = self._head
        while p != None and i < pos -1:
          if p._datum == item:
            return 1
          p = p._next
          i += 1
        return -1
      def empty(self):
        if self._head == None:
          return 1
        return 0
      def size(self):
        i = 0
        p = self._head
        while p != None and i < pos -1:
          p = p._next
          i += 1
        return i
    
      def clear(self):
        self._head = None
        self._tail = None
    
    test = LinkedList()
    test.prepend('test0')
    print test.insert(1, 'test')
    print test.head.datum
    print test.head.next.datum
    
    

    希望本文所述对大家的Python程序设计有所帮助。

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:Python 单链表
    上一篇:Python中itertools模块用法详解 下一篇:Python中unittest用法实例
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• Python的functools模块使用总结• Python轻量级搜索工具Whoosh的使用(总结分享)• python正则表达式如何实现重叠匹配• 总结分享Python冷门的技巧• python虚拟环境配置与管理
    1/1

    PHP中文网