剑指 Offer 06. 从尾到头打印链表

1.题目:

 

输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。

 

示例 1:

输入:head = [1,3,2]
输出:[2,3,1]
 

限制:

0 <= 链表长度 <= 10000

 

2.分析与代码:

方法一:递归

  (1)用递归将链表中的数据一个一个放入tmp数组,因为是递归,所以tmp中的数据已经是反序的了,可以直接返回。

代码如下:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
    vector<int> tmp;
public:
    vector<int> reversePrint(ListNode* head) {
        //递归
        recur(head);
        return tmp;
    }

    void recur(ListNode* head){
        if(head == NULL)
            return ;
        recur(head->next);
        tmp.push_back(head->val);
    }
};

(2)时间复杂度分析:递归算法的时间复杂度本质上是要看: 递归的次数 * 每次递归中的操作次数。

代码中递归了n次,每一次递归都进行1次push_back操作,所以时间复杂度为O(n)。

空间复杂度分析:使用了tmp数组,为O(1)。

 

 

posted @ 2022-08-11 22:32  湘summer  阅读(26)  评论(0)    收藏  举报