力扣-445题(Java)-两数相加使用栈+进位等惯用代码+反转链表有大宝

题目链接:https://leetcode-cn.com/problems/add-two-numbers-ii/
题目如下:
在这里插入图片描述
思路1:

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        //思路1、反转链表,相加,反转链表
        //思路2、开栈  (这个程序使用思路2)
        Stack<Integer> num1=new Stack<Integer>();
        Stack<Integer> num2=new Stack<Integer>();

        while(l1!=null){
            num1.push(l1.val);
            l1=l1.next;
        }

        while(l2!=null){
            num2.push(l2.val);
            l2=l2.next;
        }

        ListNode result=new ListNode(-1);//待返回的结果链表
        int carry=0;//进位
        while(num1.empty()==false&&num2.empty()==false){
            int p1=num1.pop();
            int p2=num2.pop();
            //惯用相加代码
            int cur=p1+p2+carry;
            if(cur>=10) {
                carry=cur/10;
                cur=cur%10;
            }
            else carry=0;
            //
            
            //惯用在链头增加节点
            ListNode p=new ListNode(cur);//每次添加链表节点到末尾
            p.next=result.next;
            result.next=p;
            //
        }

        while(num1.empty()==false){
            int p1=num1.pop();

            int cur=carry+p1;
            if(cur>=10) {carry=cur/10;cur=cur%10;}
            else carry=0;

            ListNode p=new ListNode(cur);
            p.next=result.next;
            result.next=p;
        }

        while(num2.empty()==false){
            int p1=num2.pop();

            int cur=carry+p1;
            if(cur>=10) {carry=cur/10;cur=cur%10;}
            else carry=0;

            ListNode p=new ListNode(cur);//每次添加链表节点到末尾
            p.next=result.next;
            result.next=p;
        }

        if(carry==1) {
            ListNode p=new ListNode(1);//每次添加链表节点到末尾
            p.next=result.next;
            result.next=p;
        }

        return result.next;
    }
}

思路2:(new+important+反转链表大宝帮助)
在这里插入图片描述

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    
    //思路1、反转链表,相加,反转链表 (这个程序使用思路1)
    //思路2、开栈

    public ListNode reverselist(ListNode head){//反转链表
        //原始:a->b->c
        ListNode a=head,b=head.next;
        while(b!=null){
            ListNode c=b.next;
            b.next=a; //操作后:a->b->a
            a=b; //操作后:b->a
            b=c; //操作后:c->b->a
        }
        head.next=null;//head即a,操作后:c->b->a->null
        return a;
    }

    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        l1=reverselist(l1);
        l2=reverselist(l2);

        ListNode result=new ListNode(-1);
        int cur=0;
        while(l1!=null||l2!=null||cur!=0){
            if(l1!=null) {cur+=l1.val;l1=l1.next;}
            if(l2!=null) {cur+=l2.val;l2=l2.next;}

            ListNode p=new ListNode(cur%10);//每次再链头放入节点
            p.next=result.next;
            result.next=p;

            cur=cur/10;

        }

        return result.next;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值