剑指offer_面试题6 : 从尾到头打印链表 ( python实现 )

本文介绍如何使用Python实现从尾到头打印链表,通过栈和递归两种方法解决剑指Offer面试题6。首先,创建一个链表,然后分别用栈的后进先出特性和递归的反向传递来实现链表的反向打印。
摘要由CSDN通过智能技术生成

从尾到头打印链表 ( python实现 )

一、题目描述

题目:输入一个链表的头节点,从尾到头反过来打印出每个节点的值。

  其实,在这链表操作中,从头到尾打印一遍只需要一个简单的遍历便可以做到。然而在这里,遍历的顺序是从头到尾,而打印的顺序是从尾到头,这就是典型的 “先进后出”,因此,可采用 或着 递归 实现。

二、解题思路

  暂略。(此处主要作为书中python实现补充)

三、代码实现

  先用 python 简单实现一个链表,如下。关于链表更多的操作 python 实现见 单向链表的创建及基本操作

class LinkedListNode(object):
    def __init__(self,next=None,value=None):
        self.next = next
        self.value = value
# 采用一下方式简单的创建一个链表
# 由于链表新插入的节点在表头,因此,实际上链表中的顺序,与插入列表的顺序是反过来
pHead = LinkedListNode()
myList = [1,2,3,4,5,6,7,8,9]
for i in range(len(myList)):
    pHead = LinkedListNode(pHead,myList[i])

  以上新建了链表,其遍历顺序为:9 8 7 6 5 4 3 2 1

  接下来,利用两种方式实现从尾到头打印链表。


1 栈:

def printLinkedListReversingly_stack(pHead):
    if pHead.value==None:
    return False
    tempList = []
    while pHead.value:
        tempList.append(pHead.value)
        pHead = pHead.next
    while tempList:
        print(tempList.pop())
>>> printLinkedListReversingly_stack(pHead)
Out:
1
2
3
4
5
6
7
8
9

  2 递归:

def printLinkedList(pHead):
    if pHead.value==None:
        return False
    printLinkedList(pHead.next)
    print(pHead.value)
>>> printLinkedList(pHead)
Out:
1
2
3
4
5
6
7
8
9
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值