Leetcode代码补全——链表
2018-06-18 02:57:06来源:未知 阅读 ()
通过补全代码可以更深刻的体会到,链表就是一个存储方式,通过一单元的存储指向下一单元,而查看单元内容通过头部开始的指针依次遍历。这是leetcode里融合两个链表的题目,具体代码如下:
#encoding=utf-8
class ListNode(object):
def __init__(self, x):
self.val = x
self.next = None
self.root = None
#添加链表节点函数
def addNode(self, val):
if self.root==None:
self.root= ListNode(x=val)
return self.root
else:
# 有头结点,则需要遍历到尾部节点,进行链表增加操作
cursor = self.root
while cursor.next!= None:
cursor = cursor.next
cursor.next = ListNode(x=val)
return self.root
#下面就是题目具体解决过程
class Solution(object):
def mergeTwoLists(self, l1, l2):
"""
:type l1: ListNode
:type l2: ListNode
:rtype: ListNode
"""
head=ListNode(0)
cur=head
while(l1!=None and l2!=None):
if l1.val<l2.val:
cur.next=l1
l1=l1.next
else:
cur.next=l2
l2=l2.next
#cur.next.next=None
cur=cur.next
if l1!=None:
cur.next=l1
else:
cur.next=l2
return head.next
#下面也是leetcode省略部分,实例化两个链表。添加节点,进行融合操作
a=ListNode(1)
b=ListNode(1)
print a.addNode(3).addNode(4)
print b.addNode(2).addNode(4)
c=Solution()
print c.mergeTwoLists(a,b)
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:PyCharm的注册码获取
- python将图片旋转,颠倒,修改尺寸 2019-07-24
- IDLE与pycharm执行相同代码结果却不同,原因分析 2019-07-24
- 50行Python代码,教你获取公众号全部文章 2019-07-24
- python实现查找最长公共子序列 2019-07-24
- Python--代码1(接口测试:测试用例从数据库读取写到yaml文 2019-07-24
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash