给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。
你应当 保留 两个分区中每个节点的初始相对位置。
示例 1:
输入:head = [1,4,3,2,5,2], x = 3 输出:[1,2,2,4,3,5] 示例 2:
输入:head = [2,1], x = 2 输出:[1,2]
思路:
创造两个链表
注意:我们最好创造带头结点的,因为这样就不用额外去讨论了,一个链表node1是放小于x的节点,一个链表node2是放大于等于x的节点,然后去遍历
防止成环:
最后node2指向的节点不一定是最后一个节点,如果不设置node2.next为空的话,那么链表成环了。
class Solution {
public ListNode partition(ListNode head, int x) {
ListNode node1 =new ListNode(-1);
ListNode node11=node1;
ListNode node2= new ListNode(-1);
ListNode node22=node2;
while(head!=null){
if(head.val<x){
node11.next=head;
node11=node11.next;
}
else{
node22.next=head;
node22=node22.next;
}
head=head.next;
}
node11.next=node2.next;
node22.next=null;
return node1.next;
}
}