0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

LeetCode初级算法-链表02:合并两个有序链表

电子设计 来源:电子设计 作者:电子设计 2020-12-10 22:23 次阅读

LeetCode初级算法--链表02:合并两个有序链表

一、引子

这是由LeetCode官方推出的的经典面试题目清单~
这个模块对应的是探索的初级算法~旨在帮助入门算法。我们第一遍刷的是leetcode推荐的题目。

二、题目

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

示例:

输入:1->2->4, 1->3->4
输出:1->1->2->3->4->4

1、思路

首先我们看到的数一个有序的链表,所以我们可以先比较两个链表长度相等的部分,按照顺序进行排列,对于剩下一个链表的部分,直接插入到最终的链表中,详细过程见代码。

2、编程实现

python

# Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution(object):
    def mergeTwoLists(self, l1, l2):
        """
        :type l1: ListNode
        :type l2: ListNode
        :rtype: ListNode
        """
        new_head = ListNode(0)
        #返回的是合并后的列表 所以让一个节点等于这个空的节点
        pHead = new_head
        #进行排序
        while l1 and l2:
            if l1.val > l2.val:
                new_head.next = l2
                l2 = l2.next
            else:
                new_head.next = l1
                l1 = l1.next
            new_head = new_head.next
        # 遍历剩下没遍历的列表
        if l1:
            new_head.next = l1
        elif l2:
            new_head.next = l2
        return pHead.next

分享技术,乐享生活:我们的公众号计算机视觉这件小事每周推送“AI”系列资讯类文章,欢迎您的关注!

本文由博客一文多发平台 OpenWrite 发布!

审核编辑 黄昊宇
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 人工智能
    +关注

    关注

    1781

    文章

    45032

    浏览量

    232418
  • 机器学习
    +关注

    关注

    66

    文章

    8200

    浏览量

    131244
  • 深度学习
    +关注

    关注

    73

    文章

    5287

    浏览量

    120178
收藏 人收藏

    评论

    相关推荐

    数组和链表在内存中的区别 数组和链表的优缺点

    数组和链表在内存中的区别 数组和链表的优缺点  数组和链表是常见的数据结构,用于组织和存储数据。它们在内存中的存储方式以及优缺点方面存在一些显著的差异。本文将详细探讨这些差异以及它们的优缺点。 1.
    的头像 发表于 02-21 11:30 383次阅读

    数组和链表有何区别

    数组和链表的区别,这个问题,不仅面试中经常遇到,考研的同学也得掌握才行。
    的头像 发表于 02-19 15:33 248次阅读
    数组和<b class='flag-5'>链表</b>有何区别

    数据结构:删除有序链表的重复节点

    给定一个有序链表(从小到大有序)的头结点head(该结点有值),删除链表中的重复元素,使链表中的所有元素都只出现一次。如当输入 {1,1,
    的头像 发表于 12-05 15:46 409次阅读
    数据结构:删除<b class='flag-5'>有序</b><b class='flag-5'>链表</b>的重复节点

    数据结构:判断链表回文结构

    给定一个链表,判断该链表是否为回文结构。回文是指该字符串正序逆序完全一致。如当输入链表 {1,2,3,2,1} 时,断定是回文结构,输出True。
    的头像 发表于 12-01 13:26 406次阅读
    数据结构:判断<b class='flag-5'>链表</b>回文结构

    数据结构:单链表的排序

    给定一个单链表的头结点head(该结点有值),长度为n的无序单链表,对其按升序排序后,返回新链表。如当输入链表 {3,1,4,5,2} 时,经升序排列后,原
    的头像 发表于 11-30 13:56 585次阅读
    数据结构:单<b class='flag-5'>链表</b>的排序

    请问链表是怎么用的?

    链表是怎么用的?好像单片机很少用到这种数据结构,平时应用在在哪里比较多
    发表于 11-08 06:41

    C语言中链表的作用是什么?

    对C语言中指针用的很少,链表、文件操作几乎没用过,所以也不能理解到底有什么作用。各位有经常在做程序时会用到这些吗。
    发表于 11-06 06:23

    请问链表在单片机C语言中有应用吗?

    链表在单片机C语言中有应用么?
    发表于 10-16 07:28

    LinkedBlockingQueue基于单向链表的实现

    的 LinkedBlockingQueue。它的底层基于单向链表实现。 先看一看它的 Node 内部类和主要属性、构造函数。 Node static class Node E > { E item; Node next; Node
    的头像 发表于 10-13 11:41 390次阅读
    LinkedBlockingQueue基于单向<b class='flag-5'>链表</b>的实现

    C语言链表知识点(2)

    C语言链表知识点(2)
    发表于 08-22 10:38 217次阅读
    C语言<b class='flag-5'>链表</b>知识点(2)

    如何判断链表是否有环

    如何判断链表是否有环?
    发表于 08-10 17:07 545次阅读
    如何判断<b class='flag-5'>链表</b>是否有环

    如何判断两个链表是否相交,假设两个链表都没有环?

    首先,很多同学会存在一个误区,认为两个链表相交应该这样的。
    的头像 发表于 08-08 17:08 707次阅读
    如何判断<b class='flag-5'>两个</b><b class='flag-5'>链表</b>是否相交,假设<b class='flag-5'>两个</b><b class='flag-5'>链表</b>都没有环?

    如何创建单链表

    实际中经常使用的一般为带头双向循环链表。 单链表1 # include # include typedef struct node { int data; //"数据域" 保存数据元素 struct
    的头像 发表于 07-27 16:05 1043次阅读
    如何创建单<b class='flag-5'>链表</b>

    链表和双链表的区别在哪里

    链表和双链表的区别 单链表的每一个节点中只有指向下一个结点的指针,不能进行回溯。 双链表的每一个节点给中既有指向下一个结点的指针,也有指向上一个结点的指针,可以快速的找到当前节点的前
    的头像 发表于 07-27 11:20 1298次阅读
    单<b class='flag-5'>链表</b>和双<b class='flag-5'>链表</b>的区别在哪里

    链表数据结构基本概念

    链表基本概念 头指针: 头指针是指链表指向第一个结点的指针,若链表有头结点,则是指向头结点的指针。 头指针具有标识作用,所以常用头指针冠以链表的名字。 无论
    的头像 发表于 07-27 11:14 651次阅读
    <b class='flag-5'>链表</b>数据结构基本概念