常见算法 - 链表相关:按大小将链表分列给定值左右

将链表按照一定规则排序,比给定值小的在给定值左边,大于等于的在其右边,要求是稳定的。

(leetcode86)

Input: head = 1->4->3->2->5->2, x = 3
Output: 1->2->2->4->3->5


思路: 先找到首个大于给定值的(insertNode),只有依次找到小于给定值的插入到insertNode之前,直到全部遍历完。

public class L86PartitionList {

	public static ListNode partition(ListNode head, int x) {
		if(head == null){
			return null;
		}
		ListNode preHead = new ListNode(0);
		preHead.next = head; 
		ListNode pre = preHead;
		ListNode cur = head;
		ListNode insertNode = null;
		while(cur != null){
			if(cur.val >=x && insertNode == null){
				insertNode = pre;
			}
			if(cur.val < x && insertNode !=null){
				pre.next = cur.next;
				cur.next = insertNode.next;
				insertNode.next = cur;
				insertNode = cur;
				cur = pre.next;
			}else{
                pre = cur;
			    cur = cur.next;
            }
		}
		return preHead.next;
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值