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

题目

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

题解

迭代的做法,不断交换两个链表即可,有个小技巧是设置一个pre来简化操作,代码如下:

ListNode* swapPairs(ListNode* head) {
    ListNode *pre = new ListNode(0);
    pre->next = head;
    //表示处理过的List的尾,但不一定指向链表尾,如果链表节点数为双数是指向链表尾,如果为单数时指向链表倒数第二个节点
    ListNode *newListTail = pre;
    while (newListTail->next != NULL && newListTail->next->next != NULL) {
        ListNode *swapNode1 = newListTail->next;
        ListNode *swapNode2 = newListTail->next->next;
        
        //交换
        newListTail->next = swapNode2;
        swapNode1->next = swapNode2->next;
        swapNode2->next = swapNode1;
        
        //交换过后移动newListTail
        newListTail = swapNode1;
    }
    
    ListNode *newHead = pre->next;
    free(pre);
    
    return newHead;;
}

转载于:https://www.cnblogs.com/limaofuyuanzhang/p/11296649.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值