【LeetCode-2】 两数相加 (链表)

本文介绍了两种链表加法的实现方法。一种是将链表转换为整数进行加法运算后再转换回链表;另一种是直接遍历链表进行逐位加法运算。通过这两种方法的对比,帮助读者理解链表操作的基本原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目

给定两个非空链表来表示两个非负整数。位数按照逆序方式存储,它们的每个节点只存储单个数字。将两数相加返回一个新的链表。

你可以假设除了数字 0 之外,这两个数字都不会以零开头。

 

Solution 1

链表分别转成数字,做加法后再转成链表。

# 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
        """
        def l_add(node, data):  
            node.next = ListNode(data)
            tmp = node.next
            return tmp 

        def l_read(data):
            num = 0
            i = 0
            while data:
                num = num + data.val*10**i
                i = i + 1
                data = data.next 

            return num 
        
        a = l_read(l1)
        b = l_read(l2)
        result = a + b
        print(str(result))
        # r = ListNode(0)
        for i in range(len(str(result))):
            tmp = int(result/10**i)%10
            if i==0:
                r = ListNode(tmp)
                r1 = r
            else:                    
                r1 = l_add(r1, tmp)
        # print(str(r))
        
        return r

结果:和的结果正确,但转成链表时出错。位数太多无法正确计算除法。

注意:

新建链表节点,返回整个链表

a1.next=a2

a2.next=a3

...

return a1

Solution 2

按位加。

# 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
        """
        carry = 0
        cnt = 0
        while True:
            if not l1:
                l1=ListNode(0)
            if not l2:
                l2=ListNode(0)    
            tmp = l1.val + l2.val + carry
            
            if tmp>=10:
                carry = 1
            else:
                carry = 0
                
            a = tmp%10
            
            if cnt==0:
                r = ListNode(a)
                r1 = r
            else:
                r1.next = ListNode(a)
                r1 = r1.next
            
            cnt=cnt+1
            if (l1.next==None) and (l2.next==None) and (carry==0):
                break
            l1=l1.next
            l2=l2.next
        return r

 

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在 IT 领域,文档格式转换是常见需,尤其在处理多种文件类型时。本文将聚焦于利用 Java 技术栈,尤其是 Apache POI iTextPDF 库,实现 doc、xls(涵盖 Excel 2003 及 Excel 2007+)以及 txt、图片等格式文件向 PDF 的转换,并实现在线浏览功能。 从 Apache POI 起,它是一个强大的 Java 库,专注于处理 Microsoft Office 格式文件,比如 doc xls。Apache POI 提供了 HSSF XSSF 个 API,其中 HSSF 用于读写老版本的 BIFF8 格式(Excel 97-2003),XSSF 则针对新的 XML 格式(Excel 2007+)。这个 API 均具备读取写入工作表、单元格、公式、样式等功能。读取 Excel 文件时,可通过创建 HSSFWorkbook 或 XSSFWorkbook 对象来打开相应格式的文件,进而遍历工作簿中的每个 Sheet,获取行据。写入 Excel 文件时,创建新的 Workbook 对象,添加 Sheet、Row Cell,即可构建新 Excel 文件。 再看 iTextPDF,它是一个用于生成修改 PDF 文档的 Java 库,拥有丰富的 API。创建 PDF 文档时,借助 Document 对象,可定义页面尺寸、边距等属性来定制 PDF 外观。添加内容方面,可使用 Paragraph、List、Table 等元素将文本、列表表格加入 PDF,图片可通过 Image 类加载插入。iTextPDF 支持多种字体样式,可设置文本颜色、大小、样式等。此外,iTextPDF 的 TextRenderer 类能将 HTML、
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值