与君歌一曲,请君为我侧耳听“两数相加”

2. 两数相加

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

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

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

示例:

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

解题思路

俩数相加就数学一样从最低位开始相加最后到最高位,但是会有一下俩种情况。
1、一个链表小于另一个链表
        如:一个为 12344 另一个为 56 在数学计算中,计算过程为
在这里插入图片描述
但是在链表中如何控制相加的次数?当俩个链表都为空时循环结束。
2、进位1如何处理 ?
        如 99 + 1 设置一个变量记录上一次相加时是否需要进位。
俩链表相加完成后。判断进位是否为 1 ,如为 1 则结果加 1 。
3、相加过程
在这里插入图片描述

俩个链表相应结点进行计算大于10下一次计算加1;当俩个链表都相加完成时判断最后一次相加是否大于10class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        ListNode *sum = new ListNode(0);//新的链表
        ListNode *p = l1;
        ListNode *q = l2;
        ListNode *head = sum;
        int post = 0;//进位
        while(p != NULL || q != NULL)
        {
            int i = (p != NULL) ? p->val : 0;
            int j = (q != NULL) ? q->val : 0;
            int num = i + j + post;
            post = num / 10;//不用进行判断对进位进行重置
            head->next = new ListNode( num % 10);
            head = head->next;
            if (p != NULL) p = p->next;
	        if (q != NULL) q = q->next;
        }
		//俩个链表遍历完成,最高位之和是否大于10大于新链表添加一个结点;
        if(post > 0)
        {
            head->next = new ListNode(post);
        }
        return sum->next;
    }
  • 23
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值