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

从尾到头打印链表 ( 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

你可能感兴趣的:(算法面试,经典算法实现,算法面试题)