逆序输出链表的元素

逆序输出链表的元素:一般输出元素都是不改变数据结构的啦,所以要逆序输出链表的元素,先去掉将每个结点指向下一个结点改成指向上一个结点的念想先,所以,最先可以想到的就是用递归实现咯,但是递归实现有个问题,就是当元素太多的时候,会导致栈溢出,所以,我们也可以自己实现栈来存储结点的嘛,下面就用了两种方法实现.

#include <iostream>
#include <stack>

typedef struct Node
{
	int m_data;
	Node* m_next;
}Node, *List;

// 逆序输出链表-递归实现
void printListInverse1(List list)
{
	if (list)
	{
		printListInverse1(list->m_next);
		std::cout<<list->m_data<<std::endl;
	}
}

// 逆序输出链表-利用栈实现
void printListInverse2(List list)
{
	std::stack<Node*> stack_noed;
	while(!stack_noed.empty())
	{
		stack_noed.pop();
	}
	// 将所有元素先push到栈中先
	while(list)
	{
		stack_noed.push(list);
		list = list->m_next;
	}
	// 一个个出栈,然后输出
	while(!stack_noed.empty())
	{
		std::cout<<stack_noed.top()->m_data<<std::endl;
		stack_noed.pop();
	}
}

// 插入元素
void insertList(List& list, int data)
{
	if (list)
	{
		insertList(list->m_next, data);
	}
	else
	{
		Node* node = new Node;
		node->m_data = data;
		node->m_next = 0;
		list = node;
	}
}

int main()
{
	Node* list = new Node;
	list->m_next = 0;
	insertList(list, 1);
	insertList(list, 2);
	insertList(list, 3);
	insertList(list, 4);
	insertList(list, 5);
	insertList(list, 6);
	// 递归方法
	printListInverse1(list->m_next);
	// 非递归方法
	printListInverse2(list->m_next);
	return 0;
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值