两两交换链表中的节点

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


题目:


示例:


思路:

这个题有点类似于反转一个单链表,不同的地方在于这个题不全反转,所以我们不同的地方在于此题多用了一个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宝啊

愿所有美好如期而遇

相关推荐
王景程2 小时前
Java冒泡排序算法之:变种版
java·数据结构·算法
zc.ovo3 小时前
寒假康复训练2 edu111(A-C)
c语言·数据结构·算法
雾月554 小时前
LeetCode1170 比较字符串最小字母出现频次
数据结构·算法
m0_dawn4 小时前
算法竞赛(蓝桥杯)贪心算法1——数塔问题
数据结构·python·算法·职场和发展·蓝桥杯
张小小大智慧6 小时前
排序算法(C语言版)
数据结构·算法·排序算法
Ning_.7 小时前
力扣第 54 题: 螺旋矩阵
数据结构·算法·leetcode
m0_dawn8 小时前
算法(蓝桥杯)贪心算法4——拦截导弹的系统数量求解
数据结构·python·算法·职场和发展·蓝桥杯
多多*9 小时前
双端队列实战 实现滑动窗口 用LinkedList的基类双端队列Deque实现 洛谷[P1886]
java·开发语言·jvm·数据结构·redis·算法
Ly.Leo9 小时前
什么是报文的大端和小端,有没有什么记忆口诀?
数据结构
墨楠。10 小时前
数据结构学习记录-数据结构概念
数据结构·学习