leetcode习题集——2. 两数相加

13 篇文章 0 订阅

题目

给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。

如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。

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

示例
输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807

解法1

//直接计算法
public class P2_AddTowNumbers {

    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        long sum1=0,sum2=0,sum=0;
        int index1 = 0,index2 = 0;
        while (l1 != null){
            sum1 += l1.val* Math.pow(10,index1);
            index1++;
            l1 = l1.next;
        }
        while (l2 != null){
            sum2 += l2.val* Math.pow(10,index2);
            index2++;
            l2 = l2.next;
        }
        sum = sum1 + sum2;
        ListNode head = new ListNode((int)(sum%10));
//        sum = sum / 10;
        ListNode l = head;
        while (sum/10 != 0){
            sum = sum / 10;
            ListNode li = new ListNode((int)(sum%10));
            l.next = li;
            l = li;
        }
//        l.next = new ListNode(sum);
        return head;
    }

    public static void main(String[] args){
        ListNode l1 = new ListNode(9);
//        l1.next = new ListNode(8);
        ListNode l2 = new ListNode(1);
        ListNode p2 = l2;
        for(int i = 0;i<9;i++){
            p2.next = new ListNode(9);
            p2 = p2.next;
        }
//        l2.next = new ListNode(8);
        ListNode l3 = new P2_AddTowNumbers().addTwoNumbers(l1,l2);
        while (l3!= null){
            System.out.print(""+l3.val+"->");
            l3 = l3.next;
        }
    }
}

	class ListNode {
      int val;
      ListNode next;
      ListNode(int x) { val = x; }
}

这种解法有一个局限性,就是超出long表示范围的数据相加计算就无法正确显示了,如下图

在这里插入图片描述
当然这也怪题目没有说清楚范围好吧,看到这个输入值,就知道这种方法来做行不通了。

解法2

public class P2_AddTowNumbers2 {
    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        ListNode head = new ListNode(0);
        ListNode p = head;
        int rest = 0;
        while (l1 != null || l2 !=null){
            int val1 = 0,val2 = 0;
            if(l1!=null){
                val1 = l1.val;
                l1 = l1.next;
            }
            if(l2!=null){
                val2 = l2.val;
                l2 = l2.next;
            }
            ListNode pi = new ListNode((val1+val2+rest)%10);
            rest = (val1+val2+rest)/10;
            p.next = pi;
            p = pi;
        }
        if(rest != 0 ){
            p.next = new ListNode(rest);
        }
        return head.next;
    }

    public static void main(String[] args){
        ListNode l1 = new ListNode(5);
//        ListNode l11 = l1.next = new P2.ListNode(4);
//        l11.next = new P2.ListNode(3);
        ListNode l2 = new ListNode(5);
//        ListNode p2 = l2;
//        for(int i = 0;i<9;i++){
//            p2.next = new ListNode(9);
//            p2 = p2.next;
//        }
//        ListNode l22 = l2.next = new P2.ListNode(6);
//        l22.next = new P2.ListNode(4);
        P2_AddTowNumbers2 calc = new P2_AddTowNumbers2();
        ListNode l3 = calc.addTwoNumbers(l1,l2);
        while (l3!= null){
            System.out.print(""+l3.val+"->");
            l3 = l3.next;
        }
    }
}

这种解法就解决了java中基本变量类型表示的限制,根据最基本的加法运算,按位相加,逢十进一。
其中rest为每次相加的进位,(val1+val2+rest)%10为本次加法运算完成之后该位上的结果,紧接着计算下一次是否有进位rest = (val1+val2+rest)/10。

根据提供的引用内容,Leetcode 2 "两数相加"是一个涉及链表的问题。该问题给定了个非负整数,每个整数的每一位都是按照逆序的方式存储在链表中。我们需要将这个链表相,并返回一个新的链表作为结果。 具体解题思路可以使用迭代法或递归法来解决。迭代法的伪代码如下所示: ``` 初始化一个哑节点 dummy 和一个进位 carry,同时把个链表的头节点分别赋值给 p 和 q 遍历链表,直到 p 和 q 都为 None 计算当前的和 sum 为 p.val + q.val + carry 计算当前的进位 carry 为 sum // 10 创建一个新节点 node,节点的值为 sum % 10 把新节点连接到结果链表的尾部 更新 p 和 q 分别为 p.next 和 q.next 如果最后还有进位 carry,则创建一个新节点 node,节点的值为 carry,并连接到结果链表的尾部 返回结果链表的头节点 dummy.next ``` 递归法的伪代码如下所示: ``` 定义一个辅助函数 addTwoNumbersHelper,输入为个链表的头节点 p 和 q,以及进位 carry 如果 p 和 q 都为 None 且 进位 carry 为 0,则返回 None 计算当前的和 sum 为 p.val + q.val + carry 计算当前的进位 carry 为 sum // 10 创建一个新节点 node,节点的值为 sum % 10 设置新节点的下一个节点为递归调用 addTwoNumbersHelper(p.next, q.next, carry) 返回新节点 返回 addTwoNumbersHelper(p, q, 0) 的结果 以上是解决 Leetcode 2 "两数相加"问题的种方法。如果你还有其他相关问题,请
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值