【leetcode】反转链表-25-2

方法:遍历

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        ListNode* A=nullptr;
        ListNode* B=nullptr;
        while(head!=nullptr){
            B=head;
            head=head->next;
            B->next=A;
            A=B;
        }
        head=B;
        return head;

    }
};

方法:递归

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* recurveReverseList(ListNode* A,ListNode* B){
        if(B->next==nullptr){
            B->next=A;
            return B;
        }
        ListNode* T=B;
        B=B->next;
        T->next=A;
        A=T;
        return recurveReverseList(A,B);
    }
    ListNode* reverseList(ListNode* head) {
        if(head==nullptr){
            return head;
        }
        return recurveReverseList(nullptr,head);
    }
};
相关推荐
疾跑哥布林升级版7 分钟前
C++---day7
开发语言·c++·算法
MPCTHU11 分钟前
线性方程组的解法
数据结构·算法
人类群星闪耀时20 分钟前
跳跃游戏的最优解法——贪心算法的智慧与实践
算法·游戏·贪心算法
麦城稻香咖啡20 分钟前
Day51 | 3. 无重复字符的最长子串、12. 整数转罗马数字、49. 字母异位词分组、73. 矩阵置零
算法
梭七y38 分钟前
【力扣hot100题】(071)每日温度
算法·leetcode·职场和发展
Allen Wurlitzer44 分钟前
算法刷题记录——LeetCode篇(2.4) [第131~140题](持续更新)
算法·leetcode·职场和发展
ylfhpy1 小时前
Java面试黄金宝典35
java·数据库·sql·算法·面试·职场和发展
奋进的小暄1 小时前
贪心算法(16)(java)俄罗斯套娃信封问题
算法·贪心算法
咕噜咕噜啦啦1 小时前
<贪心算法>
算法·贪心算法
smallcutepanda1 小时前
0x22 深度优先搜索0x23剪枝0x24迭代加深meet-in-the-middle
算法·深度优先