题目描述
给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
思路
两两交换,然后相连,画一遍图熟悉一下交换过程就可以开始敲了,使用哑节点更方便。
解法1
1 | public ListNode swapPairs(ListNode head) { |
解法2
递归解法,见LeetCode题解
1 | public ListNode swapPairs(ListNode head) { |