leetcode 24. Swap Nodes in Pairs
2016-05-30 16:26
489 查看
题目
Given a linked list, swap every two adjacent nodes and return its head.For example,
Given 1->2->3->4, you should return the list as 2->1->4->3.
Your algorithm should use only constant space. You may not modify the values in the list, only nodes itself can be changed.
解
public ListNode swapPairs(ListNode head) { if(head == null){ return null; } // 当只有一个元素的情况 if(head.next == null){ return head; } ListNode i = head; // i指向第1个 ListNode j = i.next; // j指向第2个 ListNode k = j.next; // k指向第3个 head = head.next; while(j != null){ j.next = i; if(k!=null && k.next!=null){ // 当有偶数个节点 i.next = k.next; }else{ // 当有奇数个节点 i.next = k; } // 更新i,j,k的值,前进两格 i = k; if(k != null){ j = k.next; }else{ j = null; } if(k!=null && k.next!=null){ k = k.next.next; }else{ k = null; } } return head; }
相关文章推荐
- leetcode 179 Largest Number
- leetcode 24 Swap Nodes in Pairs
- leetcode 2 Add Two Numbers 方法1
- leetcode 2 Add Two Numbers 方法2
- leetcode----Longest Substring Without Repeating Characters
- [LeetCode]47 Permutations II
- [LeetCode]65 Valid Number
- [LeetCode]123 Best Time to Buy and Sell Stock III
- [LeetCode] String Reorder Distance Apart
- [LeetCode] Sliding Window Maximum
- [LeetCode] Find the k-th Smallest Element in the Union of Two Sorted Arrays
- [LeetCode] Determine If Two Rectangles Overlap
- [LeetCode] A Distance Maximizing Problem
- leetcode_linearList
- leetcode_linearList02
- 021-Merge Two Sorted Lists(合并两个排好序的单链表);leetcode
- LeetCode[Day 1] Two Sum 题解
- LeetCode[Day 2] Median of Two Sorted Arrays 题解
- LeetCode[Day 3] Longest Substring Without... 题解
- LeetCode [Day 4] Add Two Numbers 题解