27、链表-合并两个有序链表

思路:

这道题不需要集合放入两个链表再进行重排序,只需要两个指针,按大小进行遍历,代码如下:

java 复制代码
class Solution {
    /**
     * 1->3->5->7
     * 2->4->6->8->10->12
     * 
     * 1->3->5->7
     * h  c1
     * p
     * 2->4->6->8->10->12
     * c2
     * 
     * 每次都是比较c1和c2 那个小 谁小p的next指针指向谁 
     *   然后c1 或者c2 向前走一位,p来到p.next 位置
     * 
     * 最后判断p.next=c1==null?c2:c1
     */
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        if (list1==null||list2==null){
            return list1==null?list2:list1;
        }
        
        ListNode head=list1.val<=list2.val?list1:list2;
        ListNode cur1=head.next;
        ListNode cur2=head==list1?list2:list1;
        ListNode pre=head;
        
        while (cur1!=null&&cur2!=null){
            if (cur1.val<=cur2.val){
                pre.next=cur1;
                cur1=cur1.next;
            }else {
                pre.next=cur2;
                cur2=cur2.next;
            }
            pre=pre.next;
        }
        pre.next=cur1==null?cur2:cur1;
        return head;
    }
}
相关推荐
云烟成雨TD17 小时前
Spring AI Alibaba 1.x 系列【6】ReactAgent 同步执行 & 流式执行
java·人工智能·spring
小O的算法实验室17 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
于慨17 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
swg32132117 小时前
Spring Boot 3.X Oauth2 认证服务与资源服务
java·spring boot·后端
gelald17 小时前
SpringBoot - 自动配置原理
java·spring boot·后端
殷紫川17 小时前
深入理解 AQS:从架构到实现,解锁 Java 并发编程的核心密钥
java
‎ദ്ദിᵔ.˛.ᵔ₎17 小时前
LIST 的相关知识
数据结构·list
一轮弯弯的明月17 小时前
贝尔数求集合划分方案总数
java·笔记·蓝桥杯·学习心得
chenjingming66617 小时前
jmeter线程组设置以及串行和并行设置
java·开发语言·jmeter
殷紫川17 小时前
深入拆解 Java volatile:从内存屏障到无锁编程的实战指南
java