《剑指offer》 第25题 合并两个排序的链表

合并两个排序的链表

http://www.nowcoder.com/questionTerminal/d8b6b4358f774294a89de2a6ac4d9337

《剑指offer》 第25题 合并两个排序的链表
题目描述
输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。

思路1:用新链表

public class Solution {
    public ListNode Merge(ListNode list1,ListNode list2) {
        if (list1 == null) {
            return list2;
        }
        if (list2 == null) {
            return list1;
        }
        ListNode newList = new ListNode(-1);
        ListNode p3 = newList;
        while (list1 != null && list2 != null) {
            if (list1.val < list2.val) {
                p3.next = list1;
                list1 = list1.next;
            } else {
                p3.next = list2;
                list2 = list2.next;
            }
            p3 = p3.next;
        }

        while (list1 != null) {
            p3.next = list1;
            list1 = list1.next;
            p3 = p3.next;
        }
      //if (list1 != null)  {
      //   p3.next = list1;} 改进写法,不用一个个去复制

        while (list2 != null) {
            p3.next = list2;
            list2 = list2.next;
            p3 = p3.next;
        }
        return newList.next;
    }
}

思路2:不使用新链表,在原链表中插入

//向链表1中插入

public class Solution {
    public ListNode Merge(ListNode list1,ListNode list2) {
        if(list1 == null ){
            return list2;
        }
        if(list2 == null){
            return list1;
        }
        if(list1 == null && list2 == null){
            return null;
        }
        ListNode list = null;  //list是要返回的头结点,因此这里比最小值,并插入给list1
        if (list1.val > list2.val) {
            list = list1;
            list1 = list2;
            list2 = list;
        }
        list = list1;
        ListNode p = null;  //p是为了记录list1的下一个节点,避免插入时链表断开
        while (list1.next != null && list2 != null) {
            // list1.next!=null 而不是list1!=null
//这是因此之前不仅比较了最小值,还将最小值直接给了list1,因此从list1的第二个节点开始比
//如果仅比较大小后就赋值个list,而不进行其他处理,那这里就是list1和list2比较了。
            if (list1.next.val <= list2.val) {
                list1 = list1.next;
            } else {   //在A->C中插入B(list1是A)
                p = list1.next;      // 记录要插入的List1 A的下一个节点C
                list1.next = list2;  // 插入比较小的list2的某节点B 连上A和B
                list2 = list2.next;  //list2往下走一个节点,准备下一轮比较
                list1 = list1.next;  //将当前节点由A变成刚刚连上的B
                list1.next = p;      //将当前节点(也就是新节点)B与之前的C连上
            }
        }
        if (list2 != null) { // 最后只关心list2不为空
            list1.next = list2;
        }
        return list;
    }
}

思路3:递归
如果list1小于list2,则list1作为新序列的开头,后面应该接的部分等同于list1.next和list2的重新排序。反之同理。因此从最开始,就没有确定一定是插入到List1或者List2,而且选择较小的。

public class Solution {
    public ListNode Merge(ListNode list1,ListNode list2) {
        if (list1 == null){
            return list2;
        }
        if (list2 == null){
            return list1;
        }
        if (list1.val<list2.val){
            list1.next = Merge(list1.next, list2);
            return list1;
        }else {
            list2.next = Merge(list2.next, list1);
            return list2;
        }
    }
}

收起

全部评论

相关推荐

不愿透露姓名的神秘牛友
2025-12-17 16:48
今天九点半到公司,我跟往常一样先扫了眼电脑,屁活儿没有。寻思着没事干,就去蹲了个厕所,回来摸出手机刷了会儿。结果老板刚好路过,拍了我一下说上班别玩手机,我吓得赶紧揣兜里。也就过了四十分钟吧,我的直属领导把我叫到小隔间,上来就给我一句:“你玩手机这事儿把老板惹毛了,说白了,你可以重新找工作了,等下&nbsp;HR&nbsp;会来跟你谈。”&nbsp;我当时脑子直接宕机,一句话都没憋出来。后面&nbsp;HR&nbsp;找我谈话,直属领导也在旁边。HR&nbsp;说我这毛病不是一次两次了,属于屡教不改,不光上班玩手机,还用公司电脑看论文、弄学校的事儿。我当时人都傻了,上班摸鱼是不对,可我都是闲得发慌的时候才摸啊!而且玩手机这事儿,从来没人跟我说过后果这么严重,更没人告诉我在公司学个习也算犯错!连一次口头提醒都没有,哪儿来的屡教不改啊?更让我膈应的是,昨天部门刚开了会,说四个实习生里留一个转正,让大家好好表现。结果今天我就因为玩手机被开了。但搞笑的是,开会前直属领导就把我叫去小会议室,明明白白告诉我:“转正这事儿你就别想了,你的学历达不到我们部门要求,当初招你进来也没打算给你这个机会。”合着我没入贵厂的眼是吧?可我都已经被排除在转正名单外了,摸个鱼至于直接把我开了吗?真的太离谱了!
rush$0522:转正名单没进,大概率本来就没打算留你
摸鱼被leader发现了...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务