合并两个有序链表算法(leetcode第21题)

题目描述:

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

示例 1:

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

输入:l1 = [], l2 = []
输出:[]
示例 3:

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

提示:

两个链表的节点数目范围是 [0, 50]
-100 <= Node.val <= 100
l1 和 l2 均按 非递减顺序 排列

算法一:

思路:

使用指针法,创建新链表,逐个存入新链表

代码实现:
# include<stdlib.h>

struct ListNode{
    int val;
    struct ListNode *next;
};

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){
    struct ListNode *newhead=(struct ListNode*)malloc(sizeof(struct ListNode));//新链表
    struct ListNode *prev=newhead;//节点指针
    while(list1!=NULL && list2!=NULL){//都不为空节点
        if(list1->val < list2->val){//list1小
            prev->next=list1;//入新链表
            list1=list1->next;//list1后移
        }
        else{//list2
            prev->next=list2;
            list2=list2->next;
        }
        prev=prev->next;//节点指针后移
    }
    prev->next=list1==NULL?list2:list1;//取另一个非空的链表节点
    return newhead->next;//返回头节点指针
}

算法二:

思路:

使用递归法,逐步缩小链表规模

判断链表节点指向值大小,小的节点指针后移,进行递归,最终合并完成

代码实现:
# include<stdlib.h>

struct ListNode{
    int val;
    struct ListNode *next;
};

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){
    if(list1==NULL){//list1为空节点
        return list2;//返回list2
    }
    else if(list2==NULL){//list2为空节点
        return list1;//返回list1
    }
    else if(list1->val < list2->val){//list1指向的值更小
        list1->next=mergeTwoLists(list1->next,list2);//list1->next递归
        return list1;//返回list1
    }
    else{//list2指向的值更小
        list2->next=mergeTwoLists(list1,list2->next);//list2->next递归
        return list2;//返回list2
    }
}

相关推荐

  1. Leetcode21 合并有序

    2023-12-22 09:54:07       38 阅读
  2. Leetcode 21合并有序

    2023-12-22 09:54:07       33 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-22 09:54:07       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-22 09:54:07       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-22 09:54:07       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-22 09:54:07       20 阅读

热门阅读

  1. Lua脚本在Redis中的高效应用

    2023-12-22 09:54:07       51 阅读
  2. LeetCode day29

    2023-12-22 09:54:07       55 阅读
  3. 基于OpenCV的视频流处理方法

    2023-12-22 09:54:07       41 阅读
  4. vue和react diff的详解和不同

    2023-12-22 09:54:07       50 阅读
  5. 前端八股文(vue篇)

    2023-12-22 09:54:07       42 阅读
  6. HTML中的6种空格标记

    2023-12-22 09:54:07       43 阅读
  7. WPF DataGrid行渲染

    2023-12-22 09:54:07       47 阅读
  8. HTMLCSS旋转的圣诞树源码附注释

    2023-12-22 09:54:07       41 阅读