LeetCode-2-Add Two Numbers(链表)-Medium

本文介绍了一种解决两个链表表示的大数相加问题的算法。通过遍历两个链表,逐位相加并处理进位,最终生成新的链表来表示相加后的结果。

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

题意理解:

将两个链表的值对应相加;


题目解析:

注意相加进位;


解题代码:

class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    	ListNode* pL1=l1;
    	ListNode* pL2=l2;
    	ListNode* pAns=NULL;
    	ListNode* pIndex;
    	int carry=0;

    	while(pL1!=NULL || pL2!=NULL){
    		int sum=0;
    		sum+=carry;
    		if(pL1!=NULL){
    			sum+=pL1->val;
    			pL1=pL1->next;
    		}

    		if(pL2!=NULL){
    			sum+=pL2->val;
    			pL2=pL2->next;
    		}

    		carry=sum/10;
    		sum%=10;

    		if(pAns==NULL){
    			pAns=new ListNode(sum);
    			pIndex=pAns;
    		}else{
    			pIndex->next=new ListNode(sum);
    			pIndex=pIndex->next;
    		}
    	}

    	if(carry!=0){
    		pIndex->next=new ListNode(carry);
    	}

    	return pAns;
    }
};


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值