给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。 你应当 保留 两个分区中每个节点的初始相对位置。 输入:head = [1,4,3,2,5,2], x = 3 输出:[1,2,2,4,3,5] 输入:head = [2,1], x = 2 输出:[1,2]
class Solution {
public ListNode partition(ListNode head, int x) {
/**
开两个节点 big small
bigHead smallHead放他们的头(而且是亚节点)
遍历head
<x small.next指向他
>x big.next指向他
*/
ListNode big=new ListNode(0);
ListNode bigHead=big;
ListNode small =new ListNode(0);
ListNode smallHead=small;
//我们操作bigHead smallHead就可
while(head!=null){
if(head.val>=x){
bigHead.next=head;
bigHead=bigHead.next;
}else if(head.val<x){
smallHead.next=head;
smallHead=smallHead.next;
}
head=head.next;
}
bigHead.next=null;
smallHead.next=big.next;
return small.next;
}
}