Python实现链表的增删遍历

class Node():
    def __init__(self, data = None, next = None, pre = None):
        self.data = data # 常量
        self.next = next # Node
        self.pre = pre

    def setData(self, data):
        self.data = data

    def setNext(self, next):
        self.next = next

    def getData(self):
        return self.data
# [1,2,3]
# node1 = Node(data=3)
# node2 = Node(data=2, next = node1)
# node3 = Node(data=1, next = node2)

class LinkedList():
    def __init__(self, node = None):
        self.head = node
        self.tail = node
    #判断是否为空
    def isempty(self):
        return self.head == None
    # 从头部加入一个元素/结点
    def add(self, item):
        # 实例化
        tmp = Node(item)
        if self.isempty():
            self.head = tmp
        else:
            tmp.setNext(self.head)
            self.head = tmp
    #从尾部添加一个元素
    def append(self, item):
        #实例化
        tmp = Node(item)
        #尾部指针
        end = self.tail
        end.setNext(tmp)
        self.tail = tmp
    #遍历
    def travel(self):
        if not self.head:
            return self.head
        else:
            cur = self.head
            while cur:
                print(cur.data, end=" ")
                cur = cur.next
        print("\n")
    #插入
    def insert(self, index, data):
        if self.isempty():
            print("链表为空")
            return
        else:
            # 实例化
            tmp = Node(data)
            # 索引
            cur = -1
            pre_node = Node(next=self.head)
            # cur = index
            while cur<index:
                # 结点和索引同步更新
                pre_node = pre_node.next
                cur += 1
                if not pre_node:
                    print("插入的位置:{}越界".format(index))
                    return
            # 插入
            tmp.setNext(pre_node.next)
            pre_node.setNext(tmp)
    #删除
    def remove(self, index):
        if self.isempty():
            print("链表为空")
            return
        elif index == 0:
            self.head = self.head.next
        else:
            # 索引
            cur = 0
            # 前置结点
            pre = self.head
            # 想退出的是cur = index - 1
            while cur < index-1:
                # 同步更新
                cur += 1
                pre = pre.next
                # 判断是否到达尾部
                if not pre.next:
                    print("越界")
                    return
            # 删除
            pre.setNext(pre.next.next) # pre tmp = pre.next pre.next.next None!=Node tail.next = None

if __name__ == "__main__":
    node1 = Node(1)
    node2 = Node(2)
    node3 = Node(3)
    list = LinkedList(node1)
    list.add(2)
    list.add(3)
    list.append(4)
    list.travel()
    list.insert(3,5)
    list.travel()
    list.insert(10,9)
    list.remove(4)
    list.travel()
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值