描述
输入一个链表的头节点,按链表从尾到头的顺序返回每个节点的值(用数组返回)。
如输入{1,2,3}的链表如下图:

返回一个数组为[3,2,1]
0 <= 链表长度 <= 10000
思路:
遍历链表的时候利用系统函数栈来达到逆序的目的
/**
* struct ListNode {
* int val;
* struct ListNode *next;
* ListNode(int x) :
* val(x), next(NULL) {
* }
* };
*/
class Solution {
private:
vector<int> res;
public:
vector<int> printListFromTailToHead(ListNode* head) {
print(head);
return res;
}
void print(ListNode* head){
if(head!=nullptr){
print(head->next);
res.emplace_back(head->val);
}
return;
}
};
该博客介绍了一种使用系统函数栈实现链表从尾到头遍历的方法,通过递归方式将链表节点值存入栈中,然后依次出栈得到逆序的节点值数组。内容涉及链表操作和栈的运用。
763

被折叠的 条评论
为什么被折叠?



