LeetCode 86. Partition List(链表)

题目来源:https://leetcode.com/problems/partition-list/

问题描述

86. Partition List

Medium

Given a linked list and a value x, partition it such that all nodes less than x come before nodes greater than or equal to x.

You should preserve the original relative order of the nodes in each of the two partitions.

Example:

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

Output: 1->2->2->4->3->5

------------------------------------------------------------

题意

给定一个无序链表和一个整数val,将链表重排,使得链表中<val的节点在>=val的节点之前。要求对于<val的节点和>=val的节点内部,不能改变节点在链表中的相对位置。

------------------------------------------------------------

思路

设置两个哑指针left和right分别指向<val的链表头和>=val的链表头,维护两个指针lprt和rptr在head指针遍历原链表的时候构造<val的左链表和>=val的右链表。然后再将lptr->next指向right->next将左右链表接上,并将rptr->next置为空。

------------------------------------------------------------

代码

/**
 * Definition for a singly-linked list.
 * class ListNode {
 *     public $val = 0;
 *     public $next = null;
 *     function __construct($val) { $this->val = $val; }
 * }
 */
class Solution {

    /**
     * @param ListNode $head
     * @param Integer $x
     * @return ListNode
     */
    function partition($head, $x) {
        $left = new ListNode(0);    // left dummy head
        $right = new ListNode(0);   // right dummy head
        $lptr = $left;
        $rptr = $right;
        while ($head)
        {
            if ($head->val < $x)
            {
                $lptr->next = $head;
                $head = $head->next;
                $lptr = $lptr->next;
            }
            else
            {
                $rptr->next = $head;
                $head = $head->next;
                $rptr = $rptr->next;
            }
        }
        $lptr->next = $right->next;
        $rptr->next = null;
        return $left->next;
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值