首页 > 编程语言 >算法6:LeetCode_合并两个有序链表

算法6:LeetCode_合并两个有序链表

时间:2022-11-25 23:59:59浏览次数:45  
标签:ListNode val minStart next 链表 算法 升序 LeetCode

题目:将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 

输入:l1 = [1,2,4], l2 = [1,3,4]     输出:[1,1,2,3,4,4]


解题思路:我们可以把两个链表合并进入一个新链表中;也可以寻找两个链表的头结点比较小的值,将另一个链表(L2)的节点插入到头结点比较小的链表(L1)中
package code.code_02;

/**
 * 力扣原题 https://leetcode.cn/problems/merge-two-sorted-lists/
 *  将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
 *  输入:l1 = [1,2,4], l2 = [1,3,4]
 *  输出:[1,1,2,3,4,4]
 *
 *  解题思路: 此题比较简单,就是单纯的合并2个链表,将数据合并进入长链表中
 *  先检查哪个链表的首节点比较小,数据往首节点比较小的链表中插入。
 *
 *  一开始我是准备往长链表中插入数据,但是发现有可能频繁更新长链表的头结点,逻辑会比较复杂,这不是一个好思路
 */
public class MergeTwoListTest {

    public class ListNode {
       int val;
       ListNode next;
       ListNode() {}
       ListNode(int val) { this.val = val; }
       ListNode(int val, ListNode next) { this.val = val; this.next = next; }
   }

    private ListNode getInsertNode (ListNode minStart, int value)
    {
        ListNode node = minStart;
        while (minStart != null && minStart.val < value) {
            if (minStart.next == null || minStart.next.val >= value) {
                node = minStart;
            }
            minStart = minStart.next;
        }
        return node;
    }

    public ListNode mergeTwoLists(ListNode list1, ListNode list2)
    {
        if (list1 == null) {
            return list2;
        }
        else if (list2 == null) {
            return list1;
        }

        ListNode minStart = (list1.val <= list2.val) ? list1 : list2;
        ListNode maxStart = (minStart == list1) ? list2 : list1;

        ListNode nextMin = null;
        ListNode nextMax = null;

        ListNode node = minStart;
        while (maxStart != null) {
            ListNode InserAfterNode = this.getInsertNode(minStart, maxStart.val);
            //如果要插入的链表已经到达链表尾部,
            nextMin = InserAfterNode.next;
            nextMax = maxStart.next;

            maxStart.next = null;
            //插入节点
            InserAfterNode.next = maxStart;
            InserAfterNode = maxStart;

            if (nextMin != null) {
                //将新插入的节点,持有原最小节点的下一个节点
                InserAfterNode.next = nextMin;

                /**
                 * 此处要尤为注意,需要考虑重复元素的问题,千万不要
                 * 这样:
                 *   InserAfterNode = nextMin
                 *   minStart = InserAfterNode
                 *
                 *   如果按照以上的写法,会出错,case为
                 *   l1 = [-10,-9,-6,-4,1,9,9]
                 *   l2 = [-5,-3,0,7,8,8]
                 */
                minStart = InserAfterNode;
            }


            //待插入节点来到下一个节点位置
            maxStart = nextMax;
        }
        return node;
    }

    // 先设计打印方法,方便检查逆转后结果
    public void printNode (ListNode node)
    {
        if (node == null) {
            System.out.println("链表不存在");
        }
        System.out.println("当前节点的值为: " + node.val);
        //递归的方式逐层打印Node的子节点
        if(node.next != null) {
            printNode(node.next);
        }
    }

    public static void main(String[] args) {
        MergeTwoListTest test = new MergeTwoListTest();
        //链表1
      /*  ListNode l1 = test.new ListNode(1);
        l1.next = test.new ListNode(2);
        l1.next.next = test.new ListNode(4);

        //链表2
        ListNode l2 = test.new ListNode(1);
        l2.next = test.new ListNode(3);
        l2.next.next = test.new ListNode(4);*/

        ListNode l1 = test.new ListNode(-10);
        l1.next = test.new ListNode(-9);
        l1.next.next = test.new ListNode(-6);
        l1.next.next.next = test.new ListNode(-4);
        l1.next.next.next.next = test.new ListNode(1);
        l1.next.next.next.next.next = test.new ListNode(9);
        l1.next.next.next.next.next.next = test.new ListNode(9);

        //链表2
        ListNode l2 = test.new ListNode(-5);
        l2.next = test.new ListNode(-3);
        l2.next.next = test.new ListNode(0);
        l2.next.next.next = test.new ListNode(7);
        l2.next.next.next.next = test.new ListNode(8);
        l2.next.next.next.next.next = test.new ListNode(8);

        ListNode nodeList = test.mergeTwoLists(l1, l2);
        test.printNode(nodeList);
    }
}

 

实测结果:

 

 

 
 

标签:ListNode,val,minStart,next,链表,算法,升序,LeetCode
From: https://www.cnblogs.com/chen1-kerr/p/16926689.html

相关文章

  • PSO 算法的变体python实现
    上演化计算课的时候老师让我们实现EOPSO算法(一种精英反向的粒子群优化算法),下面是他的算法步骤: 首先我们需要知道一些基础知识:(1)基础PSO算法 (2)精英反向解 impo......
  • 寻找链表相交结点问题
    寻找链表相交结点问题作者:Grey原文地址:博客园:寻找链表相交结点问题CSDN:寻找链表相交结点问题题目描述给定两个可能有环也可能无环的单链表,头节点head1和head2。请实......
  • 数据挖掘理论与算法,随笔1
    资源:b站本系列课程主要是启发为主,不会介绍很多很多的算法,适合初学者。一、学习资源书籍:国际会议:InternationalConferenceonDataMiningInternationalConference......
  • 快速取模算法(Barrett Reduction)
    原理:取模运算低效的原因本质是除法运算的低效。如果能将除法变成其它运算就可以加速。具体地,将除以任意数转化成“乘一个数、除以一个2k”(取262即可确保int范围内运算较为......
  • 第三周课程设计进展——基于java语言的国密算法库编译测试
    本周计划完成的任务本周实际完成情况(代码,文档,程序运行截图...),未完成计划的原因?如何改进?本周遇到的问题与解决过程(要详细)本周计划完成的任务给openeuler配置java......
  • 【SVM分类】基于鸽群算法优化支持向量机SVM实现分类附matlab的代码
    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。......
  • MATLAB图像倾斜校正算法实现:图像倾斜角检测及校正|附代码数据
    全文下载链接:http://tecdat.cn/?p=13981 在本文中,随着多媒体技术的不断发展,数码相机,高清拍照手机等多媒体设备己经在人们的生活中占据了越来越重要的地位。最近我们被......
  • 非凸算法正式上线银河证券启明 iTrade
    非凸智能算法(FT-AIWAP)正式上线银河证券启明iTrade算法中心平台,致力于为更多的量化交易类客户提供智能拆单服务,有效增厚超额收益。欢迎管理人申请试用!  ......
  • 算法思维之穷举法
    穷举法概念:穷举法是利用计算机运算速度快、精确度高的特点,对要解决问题的所有可能情况,一个不漏地进行检验,从中找出符合要求的答案,因此枚举法是通过牺牲时间来换取答案的全面......
  • LeetCode 605.种花问题
    LeetCode605.种花问题题目链接:​​https://leetcode-cn.com/problems/can-place-flowers/​​题目描述:假设有一个很长的花坛,一部分地块种植了花,另一部分却没有。可是,花不......