原创文章,转载请注明出处。
题目类型:简单
题目如下
定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL
限制:
0 <= 节点个数 <= 5000
思路1
方法一:迭代
假设链表为 1→2→3→,我们想要把它改成 1←2←3。
在遍历链表时,将当前节点的next指针改为指向前一个节点。由于节点没有引用其前一个节点,因此必须事先存储其前一个节点。在更改引用之前,还需要存储后一个节点。最后返回新的头引用。
解法1
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* reverseList(ListNode* head) {
ListNode* pRev = nullptr;
ListNode* pCur = head;
while(pCur)
{
ListNode* Node = pCur->next;
pCur->next = pRev;
pRev = pCur;
pCur = Node;
}
return pRev;
}
};
复杂度分析
时间复杂度:O(n),其中 n 是链表的长度。需要遍历链表一次。
空间复杂度:O(1)。
谢谢,创作不易,大侠请留步… 动起可爱的双手,来个关注再走呗 <( ̄︶ ̄)>