剑指 Offer 25. 合并两个排序的链表

剑指 Offer 25. 合并两个排序的链表

Offer 25

  • 该问题的原型就是多项式的合并。
  • 实现较简单,没有特殊需要注意的问题。
package com.walegarrett.offer;

/**
 * @Author WaleGarrett
 * @Date 2021/1/26 21:04
 */

/**
 * 题目解析:输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。
 */
public class Offer_25 {
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        ListNode newlist = new ListNode(-1);
        ListNode head = newlist;
        while(l1 != null && l2 != null){
            int val1 = l1.val;
            int val2 = l2.val;
            if(val1 < val2){
                l1 = l1.next;
                ListNode temp = new ListNode(val1);
                newlist.next = temp;
            }else{
                l2 = l2.next;
                ListNode temp = new ListNode(val2);
                newlist.next = temp;
            }
            newlist = newlist.next;
        }
        if(l1 != null){
            while(l1 != null){
                int val = l1.val;
                newlist.next = new ListNode(val);
                l1 = l1.next;
                newlist = newlist.next;
            }
        }else if(l2 != null){
            while(l2 != null){
                int val = l2.val;
                newlist.next = new ListNode(val);
                l2 = l2.next;
                newlist = newlist.next;
            }
        }
        return head.next;
    }
}
posted @   Garrett_Wale  阅读(51)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
点击右上角即可分享
微信分享提示