LeetCode刷题---Add Two Numbers(一)

news2025/1/10 14:13:30

文章目录

  • 🍒题目
  • 🍒解法一 迭代
  • 🍒解法二 递归
  • 🍒递归小案例
  • 🍒迭代 VS 递归

🍒题目

请添加图片描述

给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。

请你将两个数相加,并以相同形式返回一个表示和的链表。

你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

本道题,我们采用两个主流的思路,迭代递归,下面我们首先从迭代开始说起


🍒解法一 迭代

在开始编写代码之前,我们有必要了解这道题的思路,当我们读完题会感觉这题好像也就那么回事,正常加法嘛,但是上手就不知所措了

这题的核心思路主要是那个进一,还有就是l1和l2长度的问题

这题的解决配合了余数和商,在Python中就是==//(整除)、%==(取余)
好吧那么我们就可以想一下,我们可以将l1和l2的节点值相加,得到值如果整除后大于0,则作为进位值;得到的值取余即为要保存的节点
接下来我们看看代码

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:
        q = p = ListNode(None)          
        s = 0               # 令初始进位值为0
        while l1 or l2 or s:
            s += (l1.val if l1 else 0) + (l2.val if l2 else 0)  
            p.next = ListNode(s % 10)      
            p = p.next                     
            s //= 10                        
            l1 = l1.next if l1 else None    
            l2 = l2.next if l2 else None    
        return q .next   

🍒解法二 递归

递归对我,对于好多人应该都属于比较难的解法,想到了不会用,要不就是想不到哈哈哈

class Solution:
    # l1 和 l2 为当前遍历的节点,carry 为进位
    def addTwoNumbers(self, l1: Optional[ListNode], l2: Optional[ListNode], carry=0) -> Optional[ListNode]:
        if l1 is None and l2 is None:  # 递归边界:l1 和 l2 都是空节点
            return ListNode(carry) if carry else None  # 如果进位了,就额外创建一个节点
        if l1 is None:  # 如果 l1 是空的,那么此时 l2 一定不是空节点
            l1, l2 = l2, l1  # 交换 l1 与 l2,保证 l1 非空,从而简化代码
        carry += l1.val + (l2.val if l2 else 0)  # 节点值和进位加在一起
        l1.val = carry % 10  # 每个节点保存一个数位
        l1.next = self.addTwoNumbers(l1.next, l2.next if l2 else None, carry // 10)  # 进位
        return l1

复杂度分析
在这里插入图片描述

上面的代码片是我从力扣看到的,出自某位大佬手笔,喜欢这个方法的可以看看!


🍒递归小案例

当谈到递归时,经典的案例是计算阶乘、斐波那契数列和二叉树遍历。下面是这些案例的简单示例:

下面我展示一下数据结构中的二叉树遍历和斐波那契数列

class TreeNode:
    def __init__(self, value):
        self.value = value
        self.left = None
        self.right = None

def preorder_traversal(node):
    if node:
        print(node.value)
        preorder_traversal(node.left)
        preorder_traversal(node.right)

def inorder_traversal(node):
    if node:
        inorder_traversal(node.left)
        print(node.value)
        inorder_traversal(node.right)

def postorder_traversal(node):
    if node:
        postorder_traversal(node.left)
        postorder_traversal(node.right)
        print(node.value)

# 创建一个示例二叉树
root = TreeNode(1)
root.left = TreeNode(2)
root.right = TreeNode(3)
root.left.left = TreeNode(4)
root.left.right = TreeNode(5)

print("前序遍历:")
preorder_traversal(root)

print("中序遍历:")
inorder_traversal(root)

print("后序遍历:")
postorder_traversal(root)

运行结果如下
在这里插入图片描述

下面的斐波那契数列

def fibonacci(n):
    if n <= 1:
        return n
    else:
        return fibonacci(n-1) + fibonacci(n-2)

result = fibonacci(6)
print(result) 

运行结果如下
在这里插入图片描述

🍒迭代 VS 递归

迭代和递归是两种不同的问题解决方法,它们在编程中经常被用来解决各种问题,但它们有不同的工作方式和应用场景。

迭代(Iteration):

    工作原理:迭代是通过循环来重复执行一段代码,每次迭代都使用前一次迭代的结果来计算下一次的结果。这种方式通常使用for循环或while循环来实现。

    优点:
        迭代通常比递归更容易理解和调试,因为它们遵循直线性的执行流程。
        迭代通常更节省内存,因为不需要在每个递归调用之间存储调用堆栈。

    适用场景:当问题可以被划分为一系列重复的步骤,并且每个步骤都可以直接计算时,迭代通常是更好的选择。例如,遍历数组、计算阶乘等。

递归(Recursion):

    工作原理:递归是一个函数调用自身的过程,每个递归调用都会将问题分解为更小的子问题,直到达到基本情况(递归终止条件),然后开始合并这些子问题的结果来解决原始问题。

    优点:
        递归可以更自然地表达某些问题,特别是涉及到树状结构(例如二叉树、图)的问题。
        递归可以减少代码的复杂性,因为它允许将问题划分为更小的部分。

    适用场景:递归通常在问题的解决方案与其子问题的解决方案具有相似结构时非常有用。例如,树的遍历、斐波那契数列等。

比较迭代和递归的选择取决于问题的性质和个人偏好。在一些情况下,迭代更高效且更容易实现,而在另一些情况下,递归更自然且更易于理解。有时候,甚至可以将两者结合使用,例如在迭代过程中调用递归函数来处理特定的子问题。

最终,选择使用哪种方法取决于问题的具体要求以及编程语言和环境的支持。


挑战与创造都是很痛苦的,但是很充实。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1030742.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

聚观早报 | 飞书签约韵达速递;蔚来首颗自研芯片“杨戬”量产

【聚观365】9月22日消息 飞书签约韵达速递 蔚来首颗自研芯片“杨戬”10月量产 靳玉志接任华为车 BU CEO 亚马逊发布全新Alexa语音助手 OpenAI推出图像生成器DALL-E 3 飞书签约韵达速递 近日&#xff0c;国内物流服务公司韵达快递宣布全员上飞书。飞书解决方案副总裁何斌表…

【大数据】Doris 构建实时数仓落地方案详解(一):实时数据仓库概述

本系列包含&#xff1a; Doris 构建实时数仓落地方案详解&#xff08;一&#xff09;&#xff1a;实时数据仓库概述Doris 构建实时数仓落地方案详解&#xff08;二&#xff09;&#xff1a;Doris 核心功能解读Doris 构建实时数仓落地方案详解&#xff08;三&#xff09;&#…

云原生Kubernetes:K8S集群list-watch机制与 pod调度约束

目录 一、理论 1.K8S的list-watch 机制 2.亲和性 二、实验 1. 指定调度节点 2.节点亲和性 3.亲和性和反亲和 三、问题 1.新生成pod一直为pending 2.如何一次性删除pod和deployment 3.pod亲和性资源报错 4.pod反亲和性资源报错 四、总结 一、理论 1.K8S的list-wat…

zookeeper + kafka

Zookeeper 概述 Zookeeper是一个开源的分布式服务管理框架。存储业务服务节点元数据及状态信息&#xff0c;并负责通知再 ZooKeeper 上注册的服务几点状态给客户端 Zookeeper 工作机制 Zookeeper从设计模式角度来理解: 是一个基于观察者模式设计的分布式服务管理框架&…

vector的扩容机制—为何是1.5倍或者是2倍

文章目录 前言一、Vector 扩容过程二、为什么是1.5倍或者2倍&#xff1f; 前言 在 C 编程中&#xff0c;Vector 是一种常用的动态数组容器。其大小是可以动态调整的&#xff0c;而在扩容操作中&#xff0c;Vector 通常会将容量增加为原来的两倍。本篇博客将详细介绍 Vector 扩…

Kindle电子书下载功能关闭怎么办,借助calibre和cpolar搭建私有的网络书库公网访问

Kindle中国电子书店停运不要慌&#xff0c;十分钟搭建自己的在线书库随时随地看小说&#xff01; 文章目录 Kindle中国电子书店停运不要慌&#xff0c;十分钟搭建自己的在线书库随时随地看小说&#xff01;1.网络书库软件下载安装2.网络书库服务器设置3.内网穿透工具设置4.公网…

RT-Thread(学习)

RT-Thread是一款完全由国内团队开发维护的嵌入式实时操作系统&#xff08;RTOS&#xff09;&#xff0c;具有完全的自主知识产权。经过16个年头的沉淀&#xff0c;伴随着物联网的兴起&#xff0c;它正演变成一个功能强大、组件丰富的物联网操作系统。 RT-Thread概述 RT-Threa…

openssl创建CA证书教程

配置生成CA证书 总示意图&#xff1a; (1)&#xff0c;通过openssl创建CA证书 第一步&#xff1a;创建一个秘钥&#xff0c;这个便是CA证书的根本&#xff0c;之后所有的东西都来自这个秘钥 # 通过rsa算法生成2048位长度的秘钥 openssl genrsa -out myCA.key 2048 第二步&#…

Wireshark TS | MQ 传输缓慢问题

问题背景 应用传输慢是一种比较常见的问题&#xff0c;慢在哪&#xff0c;为什么慢&#xff0c;有时候光从网络数据包分析方面很难回答的一清二楚&#xff0c;毕竟不同的技术方向专业性太强&#xff0c;全栈大佬只能仰望&#xff0c;而我们能做到的是在专注于自身的专业方向之…

什么是Selenium?使用Selenium进行自动化测试!

你知道什么是 Selenium 吗&#xff1f;你知道为什么要使用它吗&#xff1f;答案就在本文中&#xff0c;很高兴能够与你共飧。 自动化测试正席卷全球&#xff0c;Selenium 认证是业界最抢手的技能之一。 什么是 Selenium&#xff1f; Selenium 是一种开源工具&#xff0c;用于…

Spring Cloud Alibaba Nacos 2.2.3 (2) - 单机版启动 (winodows 和 linux )

Nacos 2.2.3 (1) - 下载与数据库配置 参考下载与数据库配置 启动服务器 执行 nacos-server-2.2.3\bin 下的startup.sh或者startup.cmd &#xff08;根据不同系统&#xff09; windows 下nacos 单机启动 方式一&#xff1a; 1&#xff0c;打开cmd 2&#xff0c;cd 到nacos-s…

数据库数据恢复-SQL SERVER数据库分区被格式化的数据恢复方案

SQL SERVER数据库故障类型&#xff1a; 1、SQL SERVER数据库文件被删除。 2、SQL SERVER数据库所在分区格式化。 3、SQL SERVER数据库文件大小变为“0”。 4、使用备份还原数据库时覆盖原数据库。 SQL SERVER数据库故障原因&#xff1a; 1、人为误操作。 2、文件系统损坏&#…

基于Yolov8的工业小目标缺陷检测实战(2):动态蛇形卷积(Dynamic Snake Convolution),实现暴力涨点 | ICCV2023

目录 1.工业油污数据集介绍 1.1 小目标定义 1.2 难点 1.3 工业缺陷检测算法介绍 1.3.1 YOLOv8 2.Dynamic Snake Convolution 2.1 Dynamic Snake Convolution加入到yolov8 3.训练结果分析 4.系列篇 1.工业油污数据集介绍 三星油污缺陷类别&#xff1a;头发丝和小黑点&…

AirtestIDE编辑窗内,脚本内容消失,显示一片红色怎么办?

airtest编辑窗内&#xff0c;脚本内容消失&#xff0c;显示一片红色怎么办 如果突然有一天打开脚本&#xff0c;发现脚本全都变成了红色的点&#xff08;因未知错误导致的脚本异常&#xff09;&#xff1a; 原本辛辛苦苦写的三百多行代码全消失&#xff0c;是不是很难受很心慌…

Android Camera2获取摄像头的视场角(FOV)信息

一、概念 FOV&#xff08;Field of View&#xff09;是一个用于描述视野范围的术语。它通常用于计算设备&#xff08;如摄像机、虚拟现实头显或眼睛&#xff09;所能捕捉到的可见区域。 水平FOV&#xff08;Horizontal FOV&#xff09;&#xff1a;描述视野在水平方向上的范围…

可以查看输入字数的手机备忘录软件用哪个?

在当下这个科技迅速发展的时代&#xff0c;我们常常需要依赖备忘录来记录重要的信息、灵感和待办事项。手机备忘录成为了我们随身携带的工具&#xff0c;但是你有没有遇到这样的情况&#xff1a;你写了很多内容&#xff0c;但不知道写了多少字&#xff1f;这个问题或许曾经困扰…

feign结合hystrix的坑

feign结合hystrix的步骤 创建报错类 接口指向报错类 配置文件放开feign的hystrix 最后注意&#xff1a;启动类的EnableHystrix只适用于ribbon负载均衡的场景&#xff0c;如果是feign要去掉

【评论内容关键词提取】多种主流提取算法与大模型测试

文章目录 1. 写在前面2. TextRank关键词提取算法3. TFIDF算法4. jionlp算法5. sklearn算法6. Rake算法7. hanlp情感分析8. 大语言模型 1. 写在前面 做过舆情项目或文本内容情感分析的大家都知道&#xff0c;我们要从大量的文本内容中提取核心短语或者关键词&#xff01;最近我们…

【分布式计算】副本数据Replicated Data

作用&#xff1a;可靠性、高性能、容错性 问题&#xff1a;如何保持一致、如何更新 问题&#xff1a;存在读写/写写冲突 一个简单的方法就是每个操作都保持顺序&#xff0c;但是因为网络延迟会导致问题 Data-centric models: consistency model?? ??? 读取时&#xff0c…

7-1_MSPI_NANDFLASH SDK例程详解

1.代码示例路径 PRJ_M66_4.3.3\boards\apollo4l_blue_eb\examples\interfaces\mspi_ds35x1ga_quad_example\src\mspi_ds35x1ga_quad_example.c 本文中主要讲解初始化流程内容 2.MSPI通信示意图 SCK&#xff08;Serial Clock&#xff09;&#xff1a;串行时钟&#xff0c;用于…