两两交换链表中的节点

你存在,我深深的脑海里~


题目:


示例:


思路:

这个题有点类似于反转一个单链表,不同的地方在于这个题不全反转,所以我们不同的地方在于此题多用了一个prve指针保存n1的前一个节点,以及头的改变,用newhead保存一个新的头,其他都大同小异,参考:反转一个单链表


代码:

复制代码
struct ListNode* swapPairs(struct ListNode* head)
{
    if (head == NULL)
        return NULL;

    struct ListNode* newhead = head;

    struct ListNode* n1 = head;
    struct ListNode* n2 = NULL;
    struct ListNode* n3 = NULL;

    struct ListNode* prve = NULL;
    while (n1 && n1->next)
    {

        n2 = n1->next;
        n3 = n2->next;
        if (n1 == head)
        {
            n1->next = n2->next;
            n2->next = n1;
            newhead = n2;
        }
        else
        {
            n1->next = n2->next;
            n2->next = n1;

            prve->next = n2;
        }
        prve = n1;
        n1 = n3;
    }

    return newhead;
}

个人主页:Lei宝啊

愿所有美好如期而遇

相关推荐
闪电麦坤958 分钟前
数据结构:N叉树 (N-ary Tree)
数据结构·
闪电麦坤9516 分钟前
数据结构:用链表实现队列(Implementing Queue Using List)
数据结构·链表·队列
xnglan3 小时前
蓝桥杯手算题和杂题简易做法
数据结构·数据库·c++·python·算法·职场和发展·蓝桥杯
梁辰兴11 小时前
数据结构:串、数组与广义表
开发语言·数据结构·c··数组·广义表
月殇_木言14 小时前
算法基础 第3章 数据结构
数据结构·算法
亮亮爱刷题14 小时前
算法提升之树上问题-(LCA)
数据结构·算法·leetcode·深度优先
浩少70215 小时前
LeetCode-16day:栈
java·数据结构·算法
胖咕噜的稞达鸭17 小时前
数据结构---关于复杂度的基础解析与梳理
c语言·数据结构·算法·leetcode
暮乘白帝过重山17 小时前
解剖HashMap的put <三> JDK1.8
java·数据结构·hashmap·暮乘白帝过重山
猿榜20 小时前
Python基础-数据结构
大数据·数据结构·python