剑指Offer06-从尾到头打印链表-easy
作者:互联网
题目描述:
输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。
例如输入:
输入:head = [1,3,2]
输出:[2,3,1]
数据范围:
0 <= 链表长度 <= 10000
解题思路:
利用栈的后进先出的特性,遍历链表的同时往栈中插入,最后依次弹出栈中的值并保存在数组中即可。
AC代码(c++)
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
vector<int> reversePrint(ListNode* head) {
vector<int>arr;
stack<int>st;
while(head){
st.push(head->val);
head = head->next;
}
while(!st.empty()){
arr.push_back(st.top());
st.pop();
}
return arr;
}
};
标签:head,ListNode,val,st,链表,Offer06,从尾,next 来源: https://blog.csdn.net/Yang_1998/article/details/113048022