剑指offer-python刷题-合并两个排序的链表
发布日期:2021-07-28 12:03:08 浏览次数:3 分类:技术文章

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

题目:输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。


链表

线性表的链式表示,不需要使用地址连续的存志单元,即不要求逻辑上相邻的元素在物理位置上也相邻。

基本结构:

单链表:每个链表的结点除了存放元素自身的信息,还需要存放一个指向后继的指针。data存放数据,next存放后继结点的地址。

双链表:在单链表的基础上,在数据前存放前任结点的地址。

优缺点:

优点:插入和删除不需要移动其余元素,只需要修改前一个元素的指针;

缺点:失去线性表随机存取的有点,即不能直接找到表中某个特定的结点,只能从头遍历,依次查找。(不能用二分查找)


求解题目:

根据给出的头部文件,可以发现,链表中的每一个结点ListNode都有两个属性,分别存储数据val和下一个结点next。

# -*- coding:utf-8 -*-# class ListNode:#     def __init__(self, x):#         self.val = x#         self.next = Noneclass Solution:    # 返回合并后列表    def Merge(self, pHead1, pHead2):        # write code here

对于题目的求解思路还是比较简单的,只需要分别判断两个链表中当前元素,将较小的存储到新的链表中。

难点在于在python中链表的表示:使用第一个结点即可表示整个链表,不需要重新创建列表这种...当时我也是卡在这个地方,不知道如何表示了。

# -*- coding:utf-8 -*-# class ListNode:#     def __init__(self, x):#         self.val = x#         self.next = Noneclass Solution:    # 返回合并后列表    def Merge(self, pHead1, pHead2):        # write code here        pHead = ListNode(0)        #存储最终输出的结点的头部        tem = pHead        while pHead1 and pHead2:            if pHead1.val > pHead2.val:                pHead.next = pHead2                pHead2 = pHead2.next            else:                pHead.next = pHead1                pHead1 = pHead1.next            pHead = pHead.next        #只剩最后一个元素的时候,就不需要在做值的比较了        if pHead1:            pHead.next = pHead1        elif pHead2:            pHead.next = pHead2        return tem.next

在讨论区翻到了用递归思想求解这个问题的算法,觉得还蛮有意思的。

# -*- coding:utf-8 -*-# class ListNode:#     def __init__(self, x):#         self.val = x#         self.next = Noneclass Solution:    # 返回合并后列表    def Merge(self, pHead1, pHead2):        # write code here        if not pHead1:            return pHead2        elif not pHead2:            return pHead1        else:            if pHead1.val > pHead2.val:                #此时可以确定pHead2是第一个结点,但是要更新pHead2.next                pHead2.next = self.Merge(pHead1, pHead2.next)                return pHead2            else:                #此时可以确定pHead1是第一个结点,但是要更新pHead1.next                pHead1.next = self.Merge(pHead1.next, pHead2)                return pHead1

 

 

转载地址:https://blog.csdn.net/sinat_42437278/article/details/117384404 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:剑指offer-python刷题-二叉树的镜像
下一篇:剑指offer-python刷题-跳台阶扩展问题

发表评论

最新留言

感谢大佬
[***.8.128.20]2024年04月18日 23时37分18秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

08 【多线程高并发】Java线程间通信的方式 2019-04-26
【数据结构与算法】什么是跳表?通俗易懂来理解跳表 2019-04-26
【数据结构与算法】什么是图?图是什么?快速带你回顾图有关的知识点 2019-04-26
【数据结构与算法】什么是串?什么是KMP算法?字符串匹配是什么? 2019-04-26
【数据结构与算法】什么是布隆过滤器?如何防止缓存穿透的问题? 2019-04-26
【Java锁体系】CopyOnWriteArrayList是什么?线程安全的arraylist是哪个? 2019-04-26
【面试题目】Java设计模式你有哪些了解?说几个常用的。 2019-04-26
【计算机操作系统】常说的死锁是什么?死锁产生的必要条件是什么?死锁的解决策略是什么? 2019-04-26
【计算机操作系统】进程管理详解?进程与线程区别是什么?进程调度的算法有哪些?进程通信有哪些? 2019-04-26
【计算机操作系统】虚拟内存是什么?分页系统地址映射?页面置换算法有哪些?分段地址映射又是什么? 2019-04-26
【计算机操作系统】设备管理?磁盘结构是怎么样的?磁盘调度算法有哪些? 2019-04-26
【多线程高并发】为什么要使用多线程?创建多少个线程合适呢? 2019-04-26
【多线程与高并发】 Java两个线程轮流打印1-100两个数?多线程轮流打印数字? 2019-04-26
【多线程与高并发】 Java两个线程轮流打印字符串? 2019-04-26
【Linux命令篇】Linux命令实践 2019-04-26
【Leetcode单调队列】Leetcode239 滑动窗口最大值 2019-04-26
【Leetcode-单调栈】单调栈相关的题目-下一个更大的元素I 每日温度 2019-04-26
【Leetcode单调队列】- 洛谷P1714切蛋糕 2019-04-26
【Leetcode优先级队列】- 数据流的中位数 2019-04-26
【Leetcode优先级队列】-合并K个升序链表 2019-04-26