【Leetcode】Swap Nodes in Pairs

题目链接: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;
	}


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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值