电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

python實現合并兩個有序列表的示例代碼

瀏覽:98日期:2022-06-23 15:45:35
題目描述

將兩個升序鏈表合并為一個新的升序鏈表并返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。

LeetCode原題地址:https://leetcode-cn.com/problems/merge-two-sorted-lists/

測試用例

示例1

python實現合并兩個有序列表的示例代碼

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

示例2

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

示例3

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

代碼詳解

因為LeetCode服務器上已經封裝了鏈表類,在本地測試時我需要自己來實現鏈表類,代碼如下

class ListNode: def __init__(self, val, next=None): if isinstance(val,int): self.val = val self.next = next elif isinstance(val,list): self.val = val[0] self.next = None head = self for i in range(1,len(val)):node = ListNode(val[i],None)head.next = nodehead = head.next

遞歸法

遞歸法的思路比較簡單,我們需要先判斷鏈表l1和鏈表l2是否為空,如果為空直接返回另一個鏈表即可就不需要進行比較了。如果不為空,我們就需要比較鏈表節點的值誰的更大,如果l1大于l2我們就更改鏈表l2的下一個節點,然后再比較l2的下一個節點和l1,反之可得另一種情況的處理方法。

class Solution: def mergeTwoLists(self, l1: ListNode, l2: ListNode) -> ListNode: #如果鏈表l1為None直接返回鏈表l2即可 if l1 is None: return l2 #如果鏈表l2為None直接返回鏈表l1即可 elif l2 is None: return l1 #如果鏈表l1大于鏈表l2 elif l1.val > l2.val: #更改鏈表l2下一個節點的指向 l2.next = self.mergeTwoLists(l1,l2.next) return l2 else: #更改鏈表l1下一個節點的指向 l1.next = self.mergeTwoLists(l1.next,l2) return l1l1 = ListNode([1,2,4])l2 = ListNode([1,3,4])s = Solution()l = s.mergeTwoLists(l1,l2)while l: print(l.val) l = l.next

遍歷法

這個算法更簡單了,我們只需要遍歷鏈表l1和l2然后再比較大小即可,對于最后沒遍歷完的部分,直接追加到合并鏈表的后面即可。

class Solution: def mergeTwoLists(self, l1: ListNode, l2: ListNode) -> ListNode: #用來合并鏈表 prehead = ListNode(-1) #創建一個哨兵節點 pre = prehead while l1 and l2: if l1.val > l2.val:pre.next = l2l2 = l2.next else:pre.next = l1l1 = l1.next #更改哨兵節點的下一個指向 pre = pre.next pre.next = l1 if l1 else l2 return prehead.nextl1 = ListNode([1,2,4])l2 = ListNode([1,3,4])s = Solution()l = s.mergeTwoLists(l1,l2)while l: print(l.val) l = l.next

參考:合并兩個有序鏈表

到此這篇關于python實現合并兩個有序列表的示例代碼的文章就介紹到這了,更多相關python 合并兩個有序列表內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 山东氧化铁红,山东铁红-淄博科瑞化工有限公司 | 日本东丽膜_反渗透膜_RO膜价格_超滤膜_纳滤膜-北京东丽阳光官网 日本细胞免疫疗法_肿瘤免疫治疗_NK细胞疗法 - 免疫密码 | 天津蒸汽/热水锅炉-电锅炉安装维修直销厂家-天津鑫淼暖通设备有限公司 | 手机游戏_热门软件app下载_好玩的安卓游戏下载基地-吾爱下载站 | 手持式线材张力计-套帽式风量罩-深圳市欧亚精密仪器有限公司 | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 分类168信息网 - 分类信息网 免费发布与查询 | 361°官方网站 | 超声波焊接机,振动摩擦焊接机,激光塑料焊接机,超声波焊接模具工装-德召尼克(常州)焊接科技有限公司 | 诸城网站建设-网络推广-网站优化-阿里巴巴托管-诸城恒泰互联 | 免费个人pos机申请办理-移动pos机刷卡-聚合收款码办理 | sfp光模块,高速万兆光模块工厂-性价比更高的光纤模块制造商-武汉恒泰通 | 破碎机锤头_耐磨锤头_合金锤头-鼎成机械一站式耐磨铸件定制服务 微型驱动系统解决方案-深圳市兆威机电股份有限公司 | 制氮设备-变压吸附制氮设备-制氧设备-杭州聚贤气体设备制造有限公司 | 广西资质代办_建筑资质代办_南宁资质代办理_新办、增项、升级-正明集团 | 自动记录数据电子台秤,记忆储存重量电子桌称,设定时间记录电子秤-昆山巨天 | 天津货架厂_穿梭车货架_重型仓储货架_阁楼货架定制-天津钢力仓储货架生产厂家_天津钢力智能仓储装备 | 碳纤维复合材料制品生产定制工厂订制厂家-凯夫拉凯芙拉碳纤维手机壳套-碳纤维雪茄盒外壳套-深圳市润大世纪新材料科技有限公司 | 橡胶弹簧|复合弹簧|橡胶球|振动筛配件-新乡市永鑫橡胶厂 | 米顿罗计量泵(科普)——韬铭机械 | 上海橡胶接头_弹簧减震器_金属软接头厂家-上海淞江集团 | 贵州科比特-防雷公司厂家提供贵州防雷工程,防雷检测,防雷接地,防雷设备价格,防雷产品报价服务-贵州防雷检测公司 | 馋嘴餐饮网_餐饮加盟店火爆好项目_餐饮连锁品牌加盟指南创业平台 | Magnescale探规,Magnescale磁栅尺,Magnescale传感器,Magnescale测厚仪,Mitutoyo光栅尺,笔式位移传感器-苏州连达精密量仪有限公司 | 安徽合肥格力空调专卖店_格力中央空调_格力空调总经销公司代理-皖格制冷设备 | 游泳池设备安装工程_恒温泳池设备_儿童游泳池设备厂家_游泳池水处理设备-东莞市君达泳池设备有限公司 | 净化车间装修_合肥厂房无尘室设计_合肥工厂洁净工程装修公司-安徽盛世和居装饰 | 液压中心架,数控中心架,自定心中心架-烟台恒阳机电设计有限公司 行星搅拌机,双行星搅拌机,动力混合机,无锡米克斯行星搅拌机生产厂家 | B2B网站_B2B免费发布信息网站_B2B企业贸易平台 - 企资网 | 山东螺杆空压机,烟台空压机,烟台开山空压机-烟台开山机电设备有限公司 | 济南保安公司加盟挂靠-亮剑国际安保服务集团总部-山东保安公司|济南保安培训学校 | 模具ERP_模具管理系统_模具mes_模具进度管理_东莞市精纬软件有限公司 | 搅拌磨|搅拌球磨机|循环磨|循环球磨机-无锡市少宏粉体科技有限公司 | 储气罐,真空罐,缓冲罐,隔膜气压罐厂家批发价格,空压机储气罐规格型号-上海申容压力容器集团有限公司 | 哈尔滨治「失眠/抑郁/焦虑症/精神心理」专科医院排行榜-京科脑康免费咨询 一对一诊疗 | 专业的新乡振动筛厂家-振动筛品质保障-环保振动筛价格—新乡市德科筛分机械有限公司 | 地图标注|微信高德百度地图标注|地图标记-做地图[ZuoMap.com] | 铣床|万能铣床|立式铣床|数控铣床|山东滕州万友机床有限公司 | 求是网 - 思想建党 理论强党| 石油/泥浆/不锈钢防腐/砂泵/抽砂泵/砂砾泵/吸砂泵/压滤机泵 - 专业石油环保专用泵厂家 | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 |