leetcode 1721. 交换链表中的节点

Posted 旺仔古李

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode 1721. 交换链表中的节点相关的知识,希望对你有一定的参考价值。

给你链表的头节点 head 和一个整数 k 。

交换 链表正数第 k 个节点和倒数第 k 个节点的值后,返回链表的头节点(链表 从 1 开始索引)。

 

示例 1:


输入:head = [1,2,3,4,5], k = 2
输出:[1,4,3,2,5]
示例 2:

输入:head = [7,9,6,6,7,8,3,0,9,5], k = 5
输出:[7,9,6,6,8,7,3,0,9,5]
示例 3:

输入:head = [1], k = 1
输出:[1]
示例 4:

输入:head = [1,2], k = 1
输出:[2,1]
示例 5:

输入:head = [1,2,3], k = 2
输出:[1,2,3]
 

提示:

链表中节点的数目是 n
1 <= k <= n <= 105
0 <= Node.val <= 100

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/swapping-nodes-in-a-linked-list
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode swapNodes(ListNode head, int k) {
        ListNode f = new ListNode(0);
        f.next = head;
        ListNode a = f;
        int n = 1;
        while (n < k) {
            a = a.next;
            n++;
        }
        ListNode b = f;
        ListNode c = a.next.next;
        while (c != null) {
            b = b.next;
            c = c.next;
        }
        c = a.next;
        a.next = b.next;
        b.next = c;
        a = a.next;
        b = b.next;
        c = a.next;
        a.next = b.next;
        b.next = c;
        return f.next;
    }
}

以上是关于leetcode 1721. 交换链表中的节点的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode Algorithm 1721. 交换链表中的节点

leetcode 1721. 交换链表中的节点

力扣1721.交换链表中的结点(中)

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

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

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