博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
合并两个已排序的链表
阅读量:5745 次
发布时间:2019-06-18

本文共 1242 字,大约阅读时间需要 4 分钟。

合并两个已排序的链表

Merge Two Sorted Lists

  • 合并两个已排序的链表,新链表中的每个节点必须是来自输入的两个链表的节点(即不能构造新的节点),返回新链表的头部。

  • Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists.

example 1

input: 1->2->4, 3->8output: 1->2->3->4->8

思路

  1. head指向输入两个链表中头节点较小值,作为新链表的头部

  2. tail指向新链表表尾,初始状态head = tail

  3. a扫描l1,b扫描l2,比较ab节点内值的大小,将较小的加入tail之后,ab中较小的向后移动一个节点,较大的不动,tail向后移动一个节点保证任意时候指向都是新链表尾部

  4. l1l2其中一个已经遍历完,若另一个还有元素,添加到tail之后

代码

# Definition for singly-linked list.class ListNode(object):    def __init__(self, x):        self.val = x        self.next = Noneclass Solution(object):    def mergeTwoLists(self, l1, l2):        """        :type l1: ListNode        :type l2: ListNode        :rtype: ListNode        """        if None in (l1, l2):            return l1 or l2        head = tail = l1 if l1.val <= l2.val else l2        a = l1 if l1.val > l2.val else l1.next        b = l2 if l1.val <= l2.val else l2.next        while a and b:            if a.val <= b.val:                tail.next = a                tail, a = tail.next, a.next            else:                tail.next = b                tail, b = tail.next, b.next        tail.next = a or b        return head

本题以及其它leetcode题目代码github地址:

转载地址:http://ltazx.baihongyu.com/

你可能感兴趣的文章
微信帐号被封零钱怎么办?微信针对封停帐号的零钱提取出了一个流程
查看>>
数字限时增长效果实现:numberGrow.js
查看>>
Line segment matching
查看>>
读取文件最后一行的两种方式
查看>>
struts2 页面向Action传参方式
查看>>
Ubuntu 12.04嵌入式交叉编译环境arm-linux-gcc搭建过程图解
查看>>
qt sleep
查看>>
视频格式(转的豆瓣)
查看>>
laravel 5.1 的程序性能优化(配置文件)
查看>>
PasswordHasher
查看>>
Python之re模块 —— 正则表达式操作
查看>>
【HDU 5818多校】Joint Stacks
查看>>
iOS 跳转到系统的设置界面-b
查看>>
Chapter 2 Open Book——2
查看>>
oracle 11g在安装过程中出现监听程序未启动或数据库服务未注册到该监听程序
查看>>
《海量日志数据分析与应用》之报表分析与展现
查看>>
北航数值分析作业一
查看>>
企业会计准则第39号——公允价值计量
查看>>
Linux下查看文件和文件夹大小
查看>>
java.lang.reflect.InvocationTargetException
查看>>