sun-10387834
# conding:utf8
class Node():
    def __init__(self, _item):
        self.item = _item
        self.next = None


class Link():
    def __init__(self):
        self._head = None

    def append(self, _item):
        node = Node(_item)
        cur = self._head
        pre = None
        if cur == None:
            self._head = node
            return
        while cur:
            pre = cur
            cur = cur.next
        pre.next = node

    def travel(self):
        cur = self._head
        while cur:
            print(cur.item)
            cur = cur.next

    # 方式一:三个变量实现单链表倒置
    def reverse1(self):
        pre = None
        cur = self._head
        next_node = cur.next
        while cur:
            cur.next = pre
            pre = cur
            cur = next_node
            if next_node:
                next_node = next_node.next
        self._head = pre

    # 方式二:两个变量实现单链表的倒置
    def reverse2(self):
        pre = None
        cur = self._head
        while cur:
            temp = cur.next
            cur.next = pre
            pre = cur
            cur = temp
        self._head = pre


if __name__ == "__main__":
    link = Link()
    link.append(1)
    link.append(2)
    link.append(3)
    link.travel()
    print("---------------------------")
    link.reverse1()
    link.travel()

输出结果:

1
2
3
---------------------------
3
2
1

 

分类:

技术点:

相关文章:

  • 2021-10-25
  • 2021-09-13
  • 2020-10-13
  • 2021-10-02
  • 2021-10-30
  • 2021-09-17
  • 2021-06-01
猜你喜欢
  • 2022-01-07
  • 2021-07-26
  • 2021-04-01
  • 2021-07-23
  • 2021-12-06
  • 2021-10-07
  • 2021-11-10
相关资源
相似解决方案