python_ACM模式《剑指offer刷题》链表1

题目:

面试tips:

询问面试官是否可以改变链表结构

思路:

  1. 翻转链表,再遍历链表打印。

  2. 想要实现先遍历后输出,即先进后出,因此可借助栈结构。

  3. 可用隐式的栈结构,递归来实现。

代码实现:

python 复制代码
class ListNode:
    def __init__(self, val = 0, next = None):
        self.val = val
        self.next = next

class myClass:
    def printList(self, head):
        # 前后指针翻转链表
        prev, curr = None, head
        while curr:
            tmp = curr.next
            curr.next = prev
            prev, curr = curr, tmp
        # 翻转后prev即指向新链表的头节点
        # 打印链表
        curr = prev
        while curr:
            print(curr.val)
            curr = curr.next

if __name__ == '__main__':
    # 构造测试用例 -- 用数组构造链表
    arr = [5,4,2,3]
    head = ListNode(arr[0]) if arr else None
    curr = head
    for i in range(1, len(arr)):
        curr.next = ListNode(arr[i])
        curr = curr.next
    # 执行函数
    a = myClass()
    a.printList(head)
python 复制代码
class ListNode:
    def __init__(self, val = 0, next = None):
        self.val = val
        self.next = next

class myClass:
    def printList(self, head):
        # 定义一个栈,用来存储遍历过的链表节点
        stack = []
        curr = head
        while curr:
            stack.append(curr)
            curr = curr.next
        # 打印链表值,这里pop出来也可释放内存
        while stack:
            node = stack.pop()
            print(node.val)

if __name__ == '__main__':
    # 构造测试用例 -- 用数组构造链表
    arr = [5,4,2,3]
    head = ListNode(arr[0]) if arr else None
    curr = head
    for i in range(1, len(arr)):
        curr.next = ListNode(arr[i])
        curr = curr.next
    # 执行函数
    a = myClass()
    a.printList(head)

采用递归的思想 注意是递归到最后一个元素才开始打印 即要先写递归 后写打印代码

python 复制代码
class ListNode:
    def __init__(self, val = 0, next = None):
        self.val = val
        self.next = next

class myClass:
    def printList(self, head):
        # 递归打印链表 -- 递归就是栈 也就相当于使用了一个隐式的栈结构
        # 终止条件
        if not head:
            return
        # 单层递归逻辑 -- 先递归后打印
        self.printList(head.next)
        print(head.val)
        
if __name__ == '__main__':
    # 构造测试用例 -- 用数组构造链表
    arr = [5,2,6,3,5,4]
    head = ListNode(arr[0]) if arr else None
    curr = head
    for i in range(1, len(arr)):
        curr.next = ListNode(arr[i])
        curr = curr.next
    # 执行函数
    a = myClass()
    a.printList(head)
相关推荐
清风wxy37 分钟前
C语言基础数组作业(冒泡算法)
c语言·开发语言·数据结构·c++·windows·算法
程序员东岸1 小时前
避坑修链表:从顺序表到单链表的那点事儿(含可跑示例与小项目串联)
数据结构·笔记·学习·程序人生·链表
懒羊羊不懒@1 小时前
算法入门数学基础
c语言·数据结构·学习·算法
OKkankan2 小时前
list的使用和模拟实现
数据结构·c++·算法·list
爱吃生蚝的于勒3 小时前
【Linux】零基础学会linux环境基础开发工具使用(yum,vim,makefile,gdb)
linux·服务器·数据结构·c++·蓝桥杯·编辑器·vim
Chloeis Syntax17 小时前
栈和队列笔记2025-10-12
java·数据结构·笔记·
404未精通的狗17 小时前
(数据结构)线性表(下):链表分类及双向链表的实现
数据结构·链表
晨非辰19 小时前
【面试高频数据结构(四)】--《从单链到双链的进阶,读懂“双向奔赴”的算法之美与效率权衡》
java·数据结构·c++·人工智能·算法·机器学习·面试
im_AMBER19 小时前
数据结构 03 栈和队列
数据结构·学习·算法
卿言卿语21 小时前
CC1-二叉树的最小深度
java·数据结构·算法·leetcode·职场和发展