zoukankan      html  css  js  c++  java
  • python双向链表的实现

      python双向链表和单链表类似,只不过是增加了一个指向前面一个元素的指针,下面的代码实例了python双向链表的方法

    示意图:

    python双向链表实现代码

    # -*- coding: utf-8 -*-
    class Node(object):
        def __init__(self, val, p=0):
            self.data = val
            self.next = p
            self.prev = p
    
    
    class LinkList(object):
        def __init__(self):
            self.head = 0
    
        def __getitem__(self, key):
    
            if self.is_empty():
                print('linklist is empty.')
                return
    
            elif key < 0 or key > self.getlength():
                print('the given key is error')
                return
    
            else:
                return self.getitem(key)
    
        def __setitem__(self, key, value):
    
            if self.is_empty():
                print('linklist is empty.')
                return
    
            elif key < 0 or key > self.getlength():
                print('the given key is error')
                return
    
            else:
                self.delete(key)
                return self.insert(key)
    
        def initlist(self, data):
    
            self.head = Node(data[0])
    
            p = self.head
    
            for i in data[1:]:
                node = Node(i)
                p.next = node
                node.prev = p
                p = p.next
    
        def getlength(self):
    
            p = self.head
            length = 0
            while p != 0:
                length += 1
                p = p.next
    
            return length
    
        def is_empty(self):
    
            if self.getlength() == 0:
                return True
            else:
                return False
    
        def clear(self):
    
            self.head = 0
    
        def append(self, item):
    
            q = Node(item)
            if self.head == 0:
                self.head = q
            else:
                p = self.head
                while p.next != 0:
                    p = p.next
                p.next = q
                q.prev = p
    
        def getitem(self, index):
    
            if self.is_empty():
                print('Linklist is empty.')
                return
            j = 0
            p = self.head
    
            while p.next != 0 and j < index:
                p = p.next
                j += 1
    
            if j == index:
                return p.data
            else:
                print('target is not exist!')
    
        def insert(self, index, item):
    
            if self.is_empty() or index < 0 or index > self.getlength():
                print('Linklist is empty.')
                return
    
            if index == 0:
                q = Node(item, self.head)
    
                self.head = q
    
            p = self.head
            post = self.head
            j = 0
            while p.next != 0 and j < index:
                post = p
                p = p.next
                j += 1
    
            if index == j:
                q = Node(item, p)
                post.next = q
                q.prev = post
                q.next = p
                p.prev = q
    
        def delete(self, index):
    
            if self.is_empty() or index < 0 or index > self.getlength():
                print('Linklist is empty.')
                return
    
            if index == 0:
                q = Node(item, self.head)
    
                self.head = q
    
            p = self.head
            post = self.head
            j = 0
            while p.next != 0 and j < index:
                post = p
                p = p.next
                j += 1
    
            if index == j:
                post.next = p.next
                p.next.prev = post
    
        def index(self, value):
    
            if self.is_empty():
                print('Linklist is empty.')
                return
    
            p = self.head
            i = 0
            while p.next != 0 and not p.data == value:
                p = p.next
                i += 1
    
            if p.data == value:
                return i
            else:
                return -1
    
    
    l = LinkList()
    l.initlist([1, 2, 3, 4, 5])
    print(l.getitem(4))
    l.append(6)
    print(l.getitem(5))
    l.insert(4, 40)
    print(l.getitem(3))
    print(l.getitem(4))
    print(l.getitem(5))
    l.delete(5)
    print(l.getitem(5))
    l.index(5)

    输出:

    5
    6
    4
    40
    5
    6

  • 相关阅读:
    #import &lt;/usr/include/objc/objc-class.h&gt; not such file or directory问题的解决方法
    关于二进制补码
    DirectSound的应用
    Qt on Android: http下载与Json解析
    双绞线的制作,T568A线序,T568B线序
    Java设计模式之从[暗黑破坏神存档点]分析备忘录(Memento)模式
    linux 系统升级中的一些配置
    malloc函数具体解释
    老鸟的Python新手教程
    ubuntu12.04 安装配置jdk1.7
  • 原文地址:https://www.cnblogs.com/ceo-python/p/11625018.html
Copyright © 2011-2022 走看看