LeetCode 第五天 21.合并两个有序链表

LeetCode百日筑基系列主要是为了练习基础的数据结构与算法,题库全为LeetCode简单题(后面会在其他系列更新中等题和困难题),主要使用C语言和Java编写,前期的题目以完成功能为目的,后续会使用更优的算法以及优化代码块。

  1. 合并两个有序链表
    在这里插入图片描述

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

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

示例 2:

输入:l1 = [], l2 = []
输出:[]

示例 3:

输入:l1 = [], l2 = [0]
输出:[0]
C语言:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */


struct ListNode* mergeTwoLists(struct ListNode* l1, struct ListNode* l2){
    
    
    if (l1 == NULL)
    {
    
    
        return l2;
    }
    if (l2 == NULL)
    {
    
    
        return l1;
    }
    
    if(l1->val <= l2->val)
    {
    
    
        l1->next = mergeTwoLists(l1->next, l2);
        return l1;
    }
    else
    {
    
    
        l2->next = mergeTwoLists(l1, l2->next);
        return l2;
    }
}

解题思路:终止条件为当两个链表中有一个链表为NULL则直接返回另外一个链表
递归方法为判断l1,l2头节点的大小,然后将较小的next指向其余节点的合并结果。
具体体现为先把第一列第一位数字放入链表第一位,在比较第一列第二个数字和第二例第一个数字,将小的那个放入链表第二位,再依次比较,直到第一列或第二列所有数字都进入链表此时为空。
Java:

class Solution {
    
    
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
    
    
        if (l1 == null) {
    
    
            return l2;
        } else if (l2 == null) {
    
    
            return l1;
        } else if (l1.val < l2.val) {
    
    
            l1.next = mergeTwoLists(l1.next, l2);
            return l1;
        } else {
    
    
            l2.next = mergeTwoLists(l1, l2.next);
            return l2;
        }

    }
}

猜你喜欢

转载自blog.csdn.net/qq_43310387/article/details/123965963