Leetcode 445. 两数相加 II ----python

2024-08-28 05:08
文章标签 python leetcode 相加 ii 445

本文主要是介绍Leetcode 445. 两数相加 II ----python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 题目描述

给定两个非空链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储单个数字。将这两数相加会返回一个新的链表。

你可以假设除了数字 0 之外,这两个数字都不会以零开头。
示例:
输入: (7 -> 2 -> 4 -> 3) + (5 -> 6 -> 4)
输出: 7 -> 8 -> 0 -> 7

2. 解题思路

此题若不逆置初始链表,可以用栈来存储链表的值,然后相加,再把相加后的值存在新链表中。
步骤:
(1)用两个栈(stack1,stack2)分别存下两个链表的值
(2)从两个栈中取出元素,相加,相加后放在新的栈(stack3)中
(3)把新栈里的元素放入链表

3.代码实现

class Solution:def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:stack1 = []stack2 = []stack3 = []# 将两链表的元素分别入栈while(l1):stack1.append(l1.val)l1 = l1.nextwhile(l2):stack2.append(l2.val)l2 = l2.nextlend = 0# 将两链表的元素相加后,入栈while(stack1 and stack2):temp = stack1.pop(len(stack1)-1) + stack2.pop(len(stack2)-1)+ lendif(temp < 10):stack3.append(temp)lend = 0else:stack3.append(int(str(temp)[1]))lend = 1while(stack1 == [] and  stack2 != []):temp = stack2.pop(len(stack2)-1)+ lendif(temp < 10):stack3.append(temp)lend = 0else:stack3.append(int(str(temp)[1]))lend = 1while(stack2 == [] and  stack1 != []):temp = stack1.pop(len(stack1)-1) + lendif(temp < 10):stack3.append(temp)lend = 0else:stack3.append(int(str(temp)[1]))lend = 1if(lend == 1):stack3.append(1)#将栈的值放入链表dummy = ListNode(None)head = dummyfor i in stack3[::-1]:node = ListNode(i)head.next = nodehead = head.nextreturn dummy.next

在这里插入图片描述

4. 测试用例和测试结果

测试用例

# Definition for singly-linked list.
class ListNode:def __init__(self, x):self.val = xself.next = Noneclass Solution:def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:stack1 = []stack2 = []stack3 = []# 将两链表的元素分别入栈while(l1):stack1.append(l1.val)l1 = l1.nextwhile(l2):stack2.append(l2.val)l2 = l2.nextlend = 0# 将两链表的元素相加后,入栈while(stack1 and stack2):temp = stack1.pop(len(stack1)-1) + stack2.pop(len(stack2)-1)+ lendif(temp < 10):stack3.append(temp)lend = 0else:stack3.append(int(str(temp)[1]))lend = 1while(stack1 == [] and  stack2 != []):temp = stack2.pop(len(stack2)-1)+ lendif(temp < 10):stack3.append(temp)lend = 0else:stack3.append(int(str(temp)[1]))lend = 1while(stack2 == [] and  stack1 != []):temp = stack1.pop(len(stack1)-1) + lendif(temp < 10):stack3.append(temp)lend = 0else:stack3.append(int(str(temp)[1]))lend = 1if(lend == 1):stack3.append(1)#将栈的值放入链表(新开辟的链表空间)dummy = ListNode(None)head = dummyfor i in stack3[::-1]:node = ListNode(i)head.next = nodehead = head.nextreturn dummy.next#打印链表操作def printLink(self,root):r = rootwhile(r):print(r.val)r = r.nextroot1 = ListNode(9)
n2 = ListNode(4)
n3 = ListNode(6)
root1.next = n2
n2.next = n3root2 = ListNode(0)
# r2 = ListNode(5)
# r3 = ListNode(7)
# root2.next = r2
# r2.next = r3s = Solution()
result= s.addTwoNumbers(root1,root2)
s.printLink(result)

测试结果:

9
4
6

这篇关于Leetcode 445. 两数相加 II ----python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113814

相关文章

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

使用Python将长图片分割为若干张小图片

《使用Python将长图片分割为若干张小图片》这篇文章主要为大家详细介绍了如何使用Python将长图片分割为若干张小图片,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果1. Python需求

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

Python视频处理库VidGear使用小结

《Python视频处理库VidGear使用小结》VidGear是一个高性能的Python视频处理库,本文主要介绍了Python视频处理库VidGear使用小结,文中通过示例代码介绍的非常详细,对大家的... 目录一、VidGear的安装二、VidGear的主要功能三、VidGear的使用示例四、VidGea

Python Invoke自动化任务库的使用

《PythonInvoke自动化任务库的使用》Invoke是一个强大的Python库,用于编写自动化脚本,本文就来介绍一下PythonInvoke自动化任务库的使用,具有一定的参考价值,感兴趣的可以... 目录什么是 Invoke?如何安装 Invoke?Invoke 基础1. 运行测试2. 构建文档3.

Python实现数据清洗的18种方法

《Python实现数据清洗的18种方法》本文主要介绍了Python实现数据清洗的18种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录1. 去除字符串两边空格2. 转换数据类型3. 大小写转换4. 移除列表中的重复元素5. 快速统

Python结合requests和Cheerio处理网页内容的操作步骤

《Python结合requests和Cheerio处理网页内容的操作步骤》Python因其简洁明了的语法和强大的库支持,成为了编写爬虫程序的首选语言之一,requests库是Python中用于发送HT... 目录一、前言二、环境搭建三、requests库的基本使用四、Cheerio库的基本使用五、结合req

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

python中os.stat().st_size、os.path.getsize()获取文件大小

《python中os.stat().st_size、os.path.getsize()获取文件大小》本文介绍了使用os.stat()和os.path.getsize()函数获取文件大小,文中通过示例代... 目录一、os.stat().st_size二、os.path.getsize()三、函数封装一、os