链表的分化

作者: IT_Matters | 来源:发表于2016-07-04 22:57 被阅读64次

对于一个链表,我们需要用一个特定阈值完成对它的分化,使得小于等于这个值的结点移到前面,大于该值的结点在后面,同时保证两类结点内部的位置关系不变。
给定一个链表的头结点head,同时给定阈值val,请返回一个链表,使小于等于它的结点在前,大于等于它的在后,保证结点值不重复。

测试样例:
{1,4,2,5},3
{1,2,4,5}

思路:

在遍历链表的过程中,对链表进行拆分,分为小于等于val的链表list1和大于val的链表list2.这里采用哨兵节点代表两个链表的头结点,省却很多判断.
特别要注意的是,要将list2尾节点的next域置为null,避免出现环.例如{1,4,2},3.拆分为两个链表后是1->2和4->2.合并之后会变成1->2<=>4,2和4成环.

import java.util.*;

/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class Divide {
    public ListNode listDivide(ListNode head, int val) {
        ListNode guard = new ListNode(0);
        guard.next = head;
        ListNode runner = guard;

        ListNode guard2 = new ListNode(0);
        ListNode runner2 = guard2;

        while (runner.next != null) {
            if (runner.next.val > val) {
                runner2.next = runner.next;
                runner2 = runner2.next;
                runner.next = runner.next.next;            
            } else {
                runner = runner.next;
            }
        }
        runner2.next=null;    //一定要将大链表的尾节点的next置为null
        runner.next = guard2.next;
        return guard.next;
       
    }
}

相关文章

  • 链表的分化

    对于一个链表,我们需要用一个特定阈值完成对它的分化,使得小于等于这个值的结点移到前面,大于该值的结点在后面,同时保...

  • 链表的分化问题

    对于一个链表,我们需要用一个特定阈值完成对它的分化,使得小于这个值的结点移到前面,等于的值在中间,大于该值的结点在...

  • 5_5链表的分化

    对于一个链表,我们需要用一个特定阈值完成对它的分化,使得小于等于这个值的结点移到前面,大于该值的结点在后面,同时保...

  • 调整链表为小于等于k的在前,大于k的在后

    调整链表为小于等于k的在前,大于k的在后 对于一个链表,我们需要用一个特定阈值完成对它的分化,使得小于等于这个值的...

  • 第一百四十章 体质分化推动中级社会整合,体质性状分化的尽头接续

    体质分化推动中级社会整合,体质性状分化的尽头接续智质性状分化

  • 分化

    第一章 散落在不同境界空间里的人与兽与兽人和机器人,造成此物种彼物种之间的隔膜越来越大的那种不同与陌生感。 ...

  • 分化

    小孩子刚刚生下来,都是差不多的。 当然都是熊孩子,区别在于谁更熊。 关于小孩子会不会出息,大人们有自己的一套认证标...

  • 分化

    “分化”良好的人的特征。 具有目标指向性 具有“目标指向性”说的是一个人能够清醒地认识到自己的价值,并且能确定什么...

  • 分化

    不知道写点什么,看到群里转发的郑爽的新闻,就点进去看了。让我震惊的不是代孕这件事本身,而且在那个群体里,人们认为这...

  • 分化

    分化:指具有相同性质的事物变成性质不同的事物,统一的事物变成分裂的事物。 学习分化:是指在同一个教学环境下,部分学...

网友评论

    本文标题: 链表的分化

    本文链接:https://www.haomeiwen.com/subject/idkhjttx.html