add two numbers

看题一脸懵逼,看中文都很懵逼,链表怎么实现的,点了debug才看到一些代码

改一下,使本地可以跑起来

# Definition for singly-linked list.
class ListNode:
def __init__(self, x):
self.val = x
self.next = None class Solution:
def addTwoNumbers(self, l1, l2):
"""
:type l1: ListNode
:type l2: ListNode
:rtype: ListNode
"""
print(listNodeToString(l1))
print(l1.val)
print(l1.next.val) def stringToListNode(input):
numbers=input
# Now convert that list into linked list
dummyRoot = ListNode(0)
ptr = dummyRoot
for number in numbers:
ptr.next = ListNode(number)
ptr = ptr.next ptr = dummyRoot.next
return ptr def listNodeToString(node):
if not node:
return "[]" result = ""
while node:
result += str(node.val) + ", "
node = node.next
return "[" + result[:-2] + "]" def main(): while True:
try: line = [2,4,3]
l1 = stringToListNode(line);
line = [5,6,4]
l2 = stringToListNode(line); ret = Solution().addTwoNumbers(l1, l2) out = listNodeToString(ret);
print(out) #throw
raise StopIteration
except StopIteration:
break if __name__ == '__main__':
main()
第1次提交
# Definition for singly-linked list.
class ListNode:
def __init__(self, x):
self.val = x
self.next = None ############## start ############## def listNodeToInt(listN):
'''链表转整数'''
result=0
i=0
node=listN
while True: if not isinstance(node,ListNode):
break
result += node.val*10**i
node=node.next
i+=1 return result def intToListNode(num):
'''整数转链表,抄袭stringToListNode '''
dummyRoot = ListNode(0)
ptr = dummyRoot
while True:
if num == 0:
break
number=num%10
num=num//10 ptr.next = ListNode(number)
ptr = ptr.next ptr = dummyRoot.next
return ptr class Solution:
def addTwoNumbers(self, l1, l2):
"""
:type l1: ListNode
:type l2: ListNode
:rtype: ListNode
"""
#list1=listNodeToString(l1)
#print(list1) i1=listNodeToInt(l1)
i2=listNodeToInt(l2)
i3=i1+i2
#print(i1,i2)
#print(i3)
l3=intToListNode(i3)
#print(listNodeToString(l3)) return l3 ############## end ############## def stringToListNode(input):
numbers=input
# Now convert that list into linked list
dummyRoot = ListNode(0)
ptr = dummyRoot
for number in numbers:
ptr.next = ListNode(number)
ptr = ptr.next ptr = dummyRoot.next
return ptr def listNodeToString(node):
if not node:
return "[]" result = ""
while node:
result += str(node.val) + ", "
node = node.next
return "[" + result[:-2] + "]" def main(): while True:
try: line = [2,4,3]
l1 = stringToListNode(line);
line = [5,6,4]
l2 = stringToListNode(line); ret = Solution().addTwoNumbers(l1, l2) out = listNodeToString(ret);
print(out) #throw
raise StopIteration
except StopIteration:
break if __name__ == '__main__':
main()

加了两个函数整数转链表和链表转整数

Wrong Answer:

Input:
[0]
[0]
Output:
[]
Expected:
[0]

应该是整数转链表时num==0直接跳过了,在前面用number当个标志位就好了

def intToListNode(num):
'''整数转链表,抄袭stringToListNode '''
dummyRoot = ListNode(0)
ptr = dummyRoot
number=-1
while True:
if num == 0:
if number==-1:
ptr.next=ListNode(0)
break
number=num%10
num=num//10 ptr.next = ListNode(number)
ptr = ptr.next ptr = dummyRoot.next
return ptr

提交AC。

总结:学到了链表??既然没学懂,就去弄个链表。

#

class Node(object):
'''节点类''' def __init__(self,data, pnext=None):
'''
data: 节点保存的数据
_next: 保存下一个节点对象
'''
self.data = data
self._next = pnext def __repr__(self):
return str(self.data) class ListNode(object):
'''链表类'''
def __init__(self):
self.head=None
self.lenght=0 def isEmpty(self):
'''判断是否为空'''
return (self.length==0) def append(self,data):
'''增加一个节点'''
item=None
if isinstance(data,Node):
item = data
else:
item = Node(data) #如果头不存在
if not self.head:
self.head = item
self.length = 1
else:
# 如果存在找到末尾然后添加节点
node = self.head
while node._next:
node = node._next
node._next=item
self.length+=1 def delete(self,index):
'''删除一个节点'''
if self.isEmpty():
print("listNode is empty")
return False # 删除头节点
if index == 0:
self.head=self.head._next
self.length-=1
return True j=0
node = self.head
prev = self.head
while node._next and j<index:
prev=node
node=node._next
j+=1 if j==index:
prev._next = node._next
self.length-=1 def getNode(self,index,data=None,update=False):
'''查找节点'''
if self.isEmpty():
print("listNode is empty")
return False
j=0
node=self.head
while node._next and j<index:
node = node._next
j+=1 # 更新
if update:
if j==index:
node.data=data
return return node.data def update(self,index,data):
'''更新节点'''
self.getNode(index,data,True) def getIndex(self,data):
'''查找索引'''
if self.isEmpty():
print("listNode is empty")
return False # 索引列表
index=[] j=0
node=self.head
while node:
if node.data == data:
index.append(j)
node=node._next
j+=1 indexLen=len(index)
if indexLen==0:
return False
elif indexLen==1:
return index[0]
else:
print(" index not only , is list. ")
return index def insert(self,index,data):
'''插入节点'''
if self.isEmpty():
print("listNode is empty, so append data")
index=0
self.head=None
self.append(data)
return True item = None
if isinstance(data,Node):
item = data
else:
item = Node(data) if index==0:
item._next = self.head
self.head = item
self.length += 1 j = 0
node = self.head
prev = self.head
while node._next and j<index:
prev=node
node=node._next
j+=1 if j == index :
item._next = node
prev._next = item
return True def clear(self):
self.head = None
self.length = 0 def __repr__(self):
'''字符串'''
if not self.head:
return ' empty listNode ' s=[]
node = self.head
while node:
s.append(str(node.data))
node = node._next return " -> ".join(s) def __getitem__(self,index):
'''索引取值'''
return self.getNode(index) def __setitem__(self,index,value):
'''设置值'''
print(index)
self.update(index,value) if __name__ == '__main__': # 创建链表
chain=ListNode() # 添加数据
print("add 10 numbers")
for i in range(10,20):
chain.append(i) print(chain) # 查找索引
print("value eq 12 is index = ",end=" ")
print(chain.getIndex(12)) # 更新上面查找的索引
print("update ")
index=chain.getIndex(12)
if isinstance(index,int):
chain.update(index,99) # 再次查找索引
print("again, value eq 12 is index = ",end=" ")
print(chain.getIndex(12)) print(" because listNode is : ")
print(chain) # 删除一个索引
print("delete index 0")
chain.delete(0)
print(chain) # insert
print("insert data")
chain.insert(1,9)
print(chain) # 直接索引获取值
print("use [] get data")
print(chain[3]) # 直接设置值
print("append same value")
chain.append(90)
chain.append(90)
print(chain) # 查找相同值索引
print("search 90 index")
print(chain.getIndex(90))



参考python数据结构之链表(一)

LeetCode 2. add two numbers && 单链表的更多相关文章

  1. LeetCode 2 Add Two Numbers(链表操作)

    题目来源:https://leetcode.com/problems/add-two-numbers/ You are given two linked lists representing two ...

  2. LeetCode(2) || Add Two Numbers && Longest Substring Without Repeating Characters

    LeetCode(2) || Add Two Numbers && Longest Substring Without Repeating Characters 题记 刷LeetCod ...

  3. 【LeetCode-面试算法经典-Java实现】【002-Add Two Numbers (单链表表示的两个数相加)】

    [002-Add Two Numbers (单链表表示的两个数相加)] 原题 You are given two linked lists representing two non-negative ...

  4. [LeetCode] 445. Add Two Numbers II 两个数字相加之二

    You are given two linked lists representing two non-negative numbers. The most significant digit com ...

  5. LeetCode:1. Add Two Numbers

    题目: LeetCode:1. Add Two Numbers 描述: Given an array of integers, return indices of the two numbers su ...

  6. leetcode 题解 Add Two Numbers(两个单链表求和)

    题目: You are given two linked lists representing two non-negative numbers. The digits are stored in r ...

  7. LeetCode第[2]题(Java):Add Two Numbers (链表相加)——Medium

    题目难度:Medium 题目: You are given two non-empty linked lists representing two non-negative integers. The ...

  8. [leetCode][016] Add Two Numbers

    [题目]: You are given two linked lists representing two non-negative numbers. The digits are stored in ...

  9. LeetCode 面试:Add Two Numbers

    1 题目 You are given two linked lists representing two non-negative numbers. The digits are stored in ...

随机推荐

  1. elasticsearch UNASSIGNED 处理

    PUT /_settings HTTP/1.1 Host: 192.168.1.12:9200 Cache-Control: no-cache Postman-Token: 1befb0fb-6492 ...

  2. centos7 svn服务器的搭建

    centos7下svn的安装与配置   1.环境 centos7 2.安装svnyum -y install subversion 3.配置 建立版本库目录mkdir /www/svndata svn ...

  3. ML平台_Angel参考

    Angel 是腾讯开源基于参数服务器(Parameter Server)理念的机器学习框架(为支持超大维度机器学习模型运算而生).核心设计理念围绕模型,它将高维度的大模型切分到多个参数服务器节点,并通 ...

  4. Modbus RTU 协议使用汇总

    原创地址:https://blog.csdn.net/u012166958/article/details/64920144 标准的Modbus 口是使用RS-232C 兼容串行接口,它定义了连接口的 ...

  5. “无法获得锁 /var/lib/dpkg/lock -open (11:资源暂时不可用)”的方法

    另外的ubuntu 问题 在更新的时候有时候会出现 “无法获得锁 /var/lib/dpkg/lock -open (11:资源暂时不可用)”的方法 解决办法: 在ubuntu系统的termial下, ...

  6. navigator 判断移动端是Android还是iOS

    let u = navigator.userAgent; let isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > - ...

  7. autoconf配置的项目,编译debug版本

    ./configure CFLAGS=" -g " 当然,c++代码就把 CFALGS 改成 CPPFLAGS

  8. 浙江财经大学第十五届大学生程序设计竞赛------B 烦恼先生打麻将

    问题 B: B - 烦恼先生打麻将 时间限制: 1 Sec  内存限制: 256 MB提交: 8  解决: 5[提交][状态][讨论版] 题目描述 输入 6 6 Z D 1S 1S 9W 5W 2S ...

  9. 解决wordpress文章归档和分类目录小工具标题重复问题

    最近更新了wordpress,发现更新后小工具中的文章归档和分类目录出现了标题重复,经检查,是部分主题下,主题的代码已经输出了标题,而wordpress的代码又再次输出了一次.于是我们需要删除word ...

  10. [转][easyui]右键菜单

    来自:Zephyr.Net开发手册 var $tab = $('#tabs'); var currentTab = $tab.tabs('getSelected'); var titles = wra ...