剑指 Offer 24. 反转链表
构建简单的单项链表
1、解题思路
首先要清楚链表的结构 1->2->3->nullptr 反转后 nullptr <- 1<- 2<- 3;
涉及链表一定画图
思路如下图
/**
* 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* pre = nullptr;
while(cur!=nullptr){
ListNode* cur = head;
ListNode* temp=cur->next;//临时存储/中转
cur->next = pre; //改变节点位置关键一步
pre = cur;
//重定向pre和cur指向下一个位置 pre指向刚交换过来的节点也就是变换后的cur,cur指向变换前的cur->next也就是temp
cur = temp;
}
return pre;
}
};
方法二使用递归:
class Solution {
public:
ListNode* recur(ListNode* cur,ListNode* pre){
//终止条件
if(cur==nullptr){ return pre;}
ListNode* res = recur(cur->next,cur);// 递归后继节点
cur->next = pre; // 修改节点引用指向
return res; // 返回反转链表的头节点
}
ListNode* reverseList(ListNode* head) {
ListNode* cur = head;
ListNode* pre = nullptr;
return recur(cur,pre);
}
};
2、构建一个简单的单项链表
简单的顺序表构建
顺序链表,讲解非常详细
类模板构建单项链表+反转
C++ STL标准库:序列容器 单向链表forward_list(C++ 11)
底子薄弱,先好好学习下别人的。