从尾到头输出一个链表的几种方法
2015-09-03 17:24
288 查看
输入一个链表,从尾到头打印链表每个节点的值。
利用栈:
利用递归:
最简单:
利用栈:
vector<int> printListFromTailToHead(struct ListNode* head) { vector<int> list; stack<int> a; struct ListNode *p = head; while(p != NULL){ a.push(p->val); p = p->next; } while(!a.empty()){ list.push_back(a.top()); a.pop(); } return list; }
利用递归:
vector<int> printListFromTailToHead(struct ListNode* head) { vector<int> dev; if(head!=NULL) { if(head->next!=NULL) { dev=printListFromTailToHead(head->next); } dev.push_back(head->val); } return dev; }
最简单:
vector<int> printListFromTailToHead(struct ListNode* head) { vector<int> v; while(head != NULL) { v.insert(v.begin(),head->val); head = head->next; } return v; }
相关文章推荐
- [EF]vs15+ef6+mysql这个问题,你遇到过么?
- 九度OJ 题目1116:加减乘除
- 海思Hi3536开发——处理器整体架构了解
- 避免代码冗余,使用接口和泛型重构Java代码
- 家庭网络
- TCP连接如何断开连接
- java_Static函数
- android.support.v4.app.BackStackRecord.doAddOp(BackStackRecord)
- 九度oj 1109
- 0825-0903搜索专题
- hdu 1231 最大连续子序列(dp)
- 【实例】html5-canvas中实现背景图片的移动
- btrfs(Btree FS)文件系统
- KMP算法的学习理解
- 九度OJ 题目1115:数字求和
- 数据结构学习笔记7-动态规划(最长公共子序列)
- 表格
- 关于redis集群的一些事
- 让UITextView文字垂直居中
- android 屏幕适配