我们可以申请两个指针,第一个指针叫 pre,最初是指向 null 的。
第二个指针 cur 指向 head,然后不断遍历 cur。
每次迭代到 cur,都将 cur 的 next 指向 pre,然后 pre 和 cur 前进一位。
都迭代完了(cur 变成 null 了),pre 就是最后一个节点了。
演示图如下:
代码如下:
class Solution {
public:
ListNode* reverseList(ListNode* head) {
ListNode *pre, *cur, *tmp;
pre = NULL;
cur = head;
tmp = NULL; //中间变量,存储cur指向的结点的下一个结点的地址
while(cur != NULL){
tmp = cur->next;
cur->next = pre;
pre = cur;
cur = tmp;
}
return pre; //返回的指针就是翻转后的链表的头节点
}
};



