leetcode 24. 两两交换链表中的节点

24. 两两交换链表中的节点

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

题解:代码随想录 ---24. 两两交换链表中的节点

c 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
/*创建一个虚拟节点:一开始该节点指向要交换的两个结点前,借助两个辅助变量完成交换,
交换完成后,该虚拟节点移动两个结点,继续进行下一轮交换,直到虚拟节点next域指向空(偶数节点),
虚拟节点next的next域指向空(注意偶数节点与奇数节点的结束条件)*/
struct ListNode* swapPairs(struct ListNode* head) {
    struct ListNode *newnoode=malloc(sizeof(struct ListNode));//创建虚拟节点
    newnoode->next=head;//指向头结点
    struct ListNode *cur=newnoode;//移动的节点
    //奇数和偶数节点的结束条件
    while(cur->next && cur->next->next)
    {
        struct ListNode *temp=cur->next; //保存第一个结点
        struct ListNode *temp1=cur->next->next->next;//保存第三个节点
        cur->next=cur->next->next;//步骤1
        cur->next->next=temp;//步骤2
        cur->next->next->next=temp1;//步骤3
        //更新节点
        cur=cur->next->next;
    }
    struct ListNode *result=newnoode->next;
    free(newnoode);
    return result;
}
相关推荐
lingchen19067 小时前
多项式的积分
算法
1白天的黑夜17 小时前
递归-21.合并两个有序链表-力扣(LeetCode)
c++·leetcode·链表·递归
坚持编程的菜鸟8 小时前
LeetCode每日一题——在区间范围内统计奇数数目
c语言·算法·leetcode
进击的圆儿8 小时前
分治算法_快速排序专题总结-----分治
算法·排序算法·分治·快排·大根堆·小根堆
前进之路98 小时前
Leetcode每日一练--35
算法·leetcode
董建光d8 小时前
【深度学习】目标检测全解析:定义、数据集、评估指标与主流算法
深度学习·算法·目标检测
赵杰伦cpp9 小时前
list的迭代器
开发语言·数据结构·c++·算法·链表·list
~~李木子~~9 小时前
机器学习集成算法实践:装袋法与提升法对比分析
人工智能·算法·机器学习
微笑尅乐9 小时前
三种思路彻底掌握 BST 判断(递归与迭代全解析)——力扣98.验证二叉搜索树
算法·leetcode·职场和发展
闻缺陷则喜何志丹9 小时前
【动态规划】数位DP的原理、模板(封装类)
c++·算法·动态规划·原理·模板·数位dp