从尾到头打印链表

简介: 题目:输入一个链表的头结点,从尾到头反过来打印出每个结点的值。 链表结点定义如下: struct ListNode { int m_nKey; ListNode *m_pNext; }; 解决这个问题肯定要遍历链表。

 

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

链表结点定义如下:

struct ListNode
{
    int  m_nKey;
    ListNode *m_pNext;
};

解决这个问题肯定要遍历链表。遍历的顺序是从头到尾的顺序,可输出的顺序却是从尾到头。也就是说第一个遍历到的结点最后一个输出,而最后一个遍历到得结点第一个输出。这就是典型的“后进先出”,可以用实现这种顺序。每经过一个结点的时候,把该结点放到一个栈中。当遍历完整个链表后,再从栈顶开始逐个输出结点的值,此时输出的结点的顺序已经反转过来了。

实现代码如下:

void PrintListReverse(ListNode *pHead)
{
	std::stack<ListNode*> nodes;

	ListNode *pNode = pHead;
	while(pNode != NULL)
	{
		nodes.push(pNode);
		pNode = pNode->m_pNext;
	}

	while(!nodes.empty())
	{
		pNode = nodes.top();
		printf("%d\t" , pNode->m_nValue);
		nodes.pop();
	}
}

 

递归在本质上就是一个栈结构,于是很自然地想到用递归来实现。要实现反过来输出链表,每访问到一个结点的时候,先递归输出它后面的结点,再输出该结点自身,这样链表的输出结构就反过来了。

实现代码如下:

void PrintListReversely(ListNode* pListHead)
{
      if(pListHead != NULL)
      {
            // Print the next node first
            if (pListHead->m_pNext != NULL)
            {
                  PrintListReversely(pListHead->m_pNext);
            }

            // Print this node
            printf("%d", pListHead->m_nKey);
      }
}

 

 

 

 

 

img_e00999465d1c2c1b02df587a3ec9c13d.jpg
微信公众号: 猿人谷
如果您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】
如果您希望与我交流互动,欢迎关注微信公众号
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。

目录
相关文章
|
2月前
剑指Offer06.从尾到头打印链表
剑指Offer06.从尾到头打印链表
27 0
|
2月前
《剑指offer》——从尾到头打印链表
《剑指offer》——从尾到头打印链表
|
2月前
|
C++
【剑指offer】-从尾到头打印链表-03/67
【剑指offer】-从尾到头打印链表-03/67
|
10月前
剑指offer-5.从尾到头打印链表
剑指offer-5.从尾到头打印链表
30 0
剑指offer_链表---从尾到头打印链表
剑指offer_链表---从尾到头打印链表
35 0
|
存储 C++
剑指offer 05. 从尾到头打印链表
剑指offer 05. 从尾到头打印链表
44 0
|
算法 前端开发
【脚趾Offer 06,07】替换空格 + 从尾到头打印链表
【脚趾Offer 06,07】替换空格 + 从尾到头打印链表
70 0
【脚趾Offer 06,07】替换空格 + 从尾到头打印链表
|
算法 Java
从尾到头打印链表(剑指offer 06)
输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。
|
存储
从尾到头打印链表
从尾到头打印链表 1、题目 2、思路 3、代码