5. 从尾到头打印链表
2015-08-20 16:21
162 查看
题目描述
输入一个链表的头结点,从尾到头反过来打印出每个结点的值。解析
逆序打印链表,我们遍历链表只能从头到尾,现在要求我们从尾到头。后进先出,可以想到用栈存储遍历的节点,然后打印出栈序列。而递归的本质就是栈结构,在打印本节点之前,先打印本节点的下一个节点。
实现
void PrintListReversingly_Iteratively(ListNode* pHead){ //用栈存储所有链表节点,然后出栈 std::stack<ListNode*> s; //将所有链表节点入栈 while(pHead!=NULL){ s.push(pHead); pHead=pHead->m_pNext; } //打印输出所有栈元素 while(s.empty() == false){ printf("%d\t",s.top()->m_nValue); s.pop(); } } void PrintListReversingly_Recursively(ListNode* pHead){ //判断传参有效性 if(pHead == NULL) return; //递归方法,打印本节点前,先打印本节点的下一个节点 if(pHead->m_pNext != NULL){ PrintListReversingly_Recursively(pHead->m_pNext); } printf("%d\t",pHead->m_nValue); }
相关文章推荐
- tomcat优化之启用gzip网页压缩加快网站访问速度
- C++ Primer 学习笔记(第五章:语句)
- UVA 11054 Gergovia的酒交易
- JAVA的StringBuffer类
- UISegmentedControl
- 使用Validation将错误串接
- TrackMouseEvent与_TrackMouseEvent
- hdu 4857 逃生(拓扑排序)
- 今15年创业,享受改变的过程(我的新书10月中旬上市)
- NuGet的使用和服务搭建
- 0-1背包问题
- 实现Android播放声音资源的一个简单的工具类
- 利用开源组件iText动态生成PDF文档
- CWnd与HWND的区别与转换
- php cms 通用后台下载
- DDX_Control和DDX_Text的区别
- 我爸爸是个程序员
- DOM(一)-07-(window常见方法_1)
- 关于数据库事务、隔离级别、锁的理解与整理
- OpenWRT(RT5350) 路由客户模式(Routed Client) ,设置防火墙开放UDP指定端口