关闭

【Leetcode】Swap Nodes in Pairs

436人阅读 评论(0) 收藏 举报
分类:

题目链接:https://leetcode.com/problems/swap-nodes-in-pairs/

题目:

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) {
		ListNode pre = null, q = head, p = head, t = null;
		if (head == null || q.next == null)
			return head;
		p = q.next;
		t = q.next.next;
		// pre q p t,调整q/p位置,以1,2,3为例
		while (p != null) {
			p.next = q; // 互换两节点
			if (pre != null) // 如果不是头节点交换
				pre.next = p;
			else
				head = p;
			pre = q; // 调整pre指针
			q = t;// 调整q 指针
			if (q != null) {
				p = q.next;// 调整p指针
				if (p != null) {
					t = p.next;// 调整t指针
				} else {
					pre.next = q;// 如果p为空,则是奇数节点,则调整尾节点一个节点指向,并跳出循环
					break;
				}
			} else // 若为空则结束循环
				break;

		}
		if (q == null) // 若为偶数节点并到末尾,则调整尾节点为空,防止存在循环
			pre.next = null;
		return head;
	}


我实现的太麻烦了,而且让我自己在一小时内再重现一遍我都没信心,不过据说链表题在面试中出现的不多。。更好的解法见:点击打开链接

0
0
查看评论

Swap Nodes in Pairs -- LeetCode

原题链接: http://oj.leetcode.com/problems/swap-nodes-in-pairs/  这道题属于链表操作的题目,思路比较清晰,就是每次跳两个节点,后一个接到前面,前一个接到后一个的后面,最后现在的后一个(也就是原来的前一个)接到下下个结点(如果没...
  • linhuanmars
  • linhuanmars
  • 2014-02-26 01:37
  • 12015

LeetCode24. Swap Nodes in Pairs简单到一次性通过

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...
  • booirror
  • booirror
  • 2016-02-02 21:01
  • 1503

LeetCode 24 Swap Nodes in Pairs(交换序列中的结点)(Linked List)

翻译给定一个链表,调换每两个相邻节点,并返回其头部。例如, 给定 1->2->3->4, 你应该返回的链表是 2->1->4->3。你的算法必须使用唯一不变的空间。你也不能修改列表中的值,只有节点本身是可以改变的。原文Give a linked list, swa...
  • NoMasp
  • NoMasp
  • 2015-11-12 18:43
  • 4279

【LeetCode-24】Swap Nodes in Pairs(C++)

交换链表中每两个相邻的节点 不能改变节点的值 智能改变节点。 递归法: class Solution { public: ListNode* swapPairs(ListNode* head) { if(head==NULL||head->next==NULL) ...
  • liujiayu1015
  • liujiayu1015
  • 2016-08-08 16:57
  • 125

(Java)LeetCode-24. Swap Nodes in Pairs

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...
  • u012848330
  • u012848330
  • 2016-06-02 16:53
  • 479

24. Swap Nodes in Pairs [easy] (Python)

题目链接https://leetcode.com/problems/swap-nodes-in-pairs/题目原文 Given a linked list, swap every two adjacent nodes and return its head. For example,...
  • coder_orz
  • coder_orz
  • 2016-05-29 15:09
  • 959

24. Swap Nodes in Pairs -leetcode-java

今天一下午被这道题困惑好久,也是够笨呀。 Given a linked list, swap every two adjacent nodes and return its head. For example, Given 1->2->3->4, you...
  • hahawhyha
  • hahawhyha
  • 2016-05-26 18:54
  • 596

[LeetCode] 024. Swap Nodes in Pairs (Medium) (C++/Python)

[LeetCode] 024. Swap Nodes in Pairs (Medium) (C++/Python)
  • hcbbt
  • hcbbt
  • 2015-03-05 14:39
  • 1621

LeetCode 24_Swap Nodes in Pairs

这几天真是忙的不可开交,主要是因为要学的东西太多了,本人又有完美主主义倾向,所以对于一些知识就非常浪费时间,这样做有点好处就是理解深刻,但缺点就是太费时间。话说回来,算法这种东西,是有必要深追究的,因为这是往大了说是一个创造的工作,往小了说最起码也是匹配吧。你最少得知道什么情况该用什么算法吧,如果你...
  • cyfcsd
  • cyfcsd
  • 2015-11-13 21:07
  • 298

leetcode Swap Nodes in Pairs java实现

描述:Given a linked list, swap every two adjacent nodes and return its head.             For example,     ...
  • a15994269853
  • a15994269853
  • 2014-03-07 12:17
  • 2220
    个人资料
    • 访问:569143次
    • 积分:8678
    • 等级:
    • 排名:第2674名
    • 原创:305篇
    • 转载:6篇
    • 译文:0篇
    • 评论:37条
    博客专栏
    文章分类
    最新评论