leetcode86. 分隔链表

举报
兔老大 发表于 2021/04/23 23:34:43 2021/04/23
1.6k+ 0 0
【摘要】 给定一个链表和一个特定值 x,对链表进行分隔,使得所有小于 x 的节点都在大于或等于 x 的节点之前。 你应当保留两个分区中每个节点的初始相对位置。 示例: 输入: head = 1->4->3->2->5->2, x = 3 输出: 1->2->2->4->3->5 思路:分别创建两个链表保存两种节点,最后...

给定一个链表和一个特定值 x,对链表进行分隔,使得所有小于 x 的节点都在大于或等于 x 的节点之前。

你应当保留两个分区中每个节点的初始相对位置。

示例:

输入: head = 1->4->3->2->5->2, x = 3
输出: 1->2->2->4->3->5

思路:分别创建两个链表保存两种节点,最后连起来即可。


      /**
       * Definition for singly-linked list.
       * public class ListNode {
       * int val;
       * ListNode next;
       * ListNode(int x) { val = x; }
       * }
       */
      class Solution {
      public ListNode partition(ListNode head, int x) {
       ListNode before_head = new ListNode(0);
       ListNode before = before_head;
       ListNode after_head = new ListNode(0);
       ListNode after = after_head;
      while (head != null) {
      if (head.val < x) {
       before.next = head;
       before = before.next;
       } else {
       after.next = head;
       after = after.next;
       }
       head = head.next;
       }
       after.next = null;
       before.next = after_head.next;
      return before_head.next;
       }
      }
  
 

文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。

原文链接:fantianzuo.blog.csdn.net/article/details/104076336

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。