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