当前位置:网站首页>2. 两数相加

2. 两数相加

2022-08-03 05:09:00 破烂摆烂人

image-20220225163645653

image-20220225163659406

方法一:初等数学

image-20220225163744285

image-20220225163855971

    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
    
         ListNode head = null, tail = null/*新建链表的头尾指针*/;
        int carry = 0/*上一位的进位*/;
        /*逐步相加:初等数学*/
        while(l1 != null && l2 != null){
    
            int sum = l1.val + l2.val + carry;
            if(head == null){
    
                head = tail = new ListNode(sum%10);
            } else {
    
                tail.next = new ListNode(sum%10);
                tail = tail.next;
            }
            carry = sum/10;
            l1 = l1.next;
            l2 = l2.next;
        }
        /*处理剩余部分(注意进位)*/
        while(l1 != null){
    
            int sum = l1.val+carry;
            tail.next = new ListNode(sum%10);
            tail = tail.next;
            l1 = l1.next;
            carry = sum/10;
        }
        while(l2 != null){
    
            int sum = l2.val+carry;
            tail.next  = new ListNode(sum%10);
            tail= tail.next;
            l2 = l2.next;
            carry = sum/10;
        }
        /*最后有可能是进位*/
        if(carry > 0){
    
            tail.next = new ListNode(carry);
            tail= tail.next;
        }
         return head;
    }

image-20220225163931236

原网站

版权声明
本文为[破烂摆烂人]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_43970098/article/details/124987321