倒序打印链表

递归实现

class Solution {
private:
    vector<int> result;
public:
    vector<int> printListFromTailToHead(ListNode* head) {
        if(head != NULL)
        {
            if(head->next!=NULL)
            {
                printListFromTailToHead(head->next);
            }
            result.push_back(head->val);
        }
        return result;
    }
};

借助栈实现

class Solution {
public:
    vector<int> printListFromTailToHead(ListNode* head) {
        ListNode *pnode = head;
        vector<int> result;
        stack<int> myresult;
        while(pnode!=NULL)
        {
            myresult.push(pnode->val);
            pnode=pnode->next;
        }
        while(!myresult.empty())
        {
            result.push_back(myresult.top());
            myresult.pop();
        }
        return result;
    }
};
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容