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. 交换链表中的节点的主要内容,如果未能解决你的问题,请参考以下文章