两数相加

思路:
1、定义一个临时变量,遍历两个链表,把当前节点的和保存在链表中。
2、定义一个临时变量保存进制数。
3、把相加的和取余数保存在新的链表中。
做题步骤:
1、拿到代码先判断链表是否为空
2、定义新的链表指向原始链表的表头,尽量不要破坏掉原始链表结构。
3、定义新链表用来存储相加信息。
4、循环遍历,相加,取余入链表。

ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    if(l1 == NULL || l2 == NULL)
        return NULL;
    int tempVar = 0;
    ListNode *list1 = l1, *list2 = l2;
    ListNode *newList = new ListNode(0); 
    ListNode *node = newList;
    while(list1 != NULL || list2 != NULL || tempVar != 0) {
        int data = 0;
        if(list1 != NULL) data += list1->val;
        if(list2 != NULL) data += list2->val;
        data += tempVar;
        tempVar = data / 10;
        data %= 10;
        ListNode *pCur = new ListNode(data);
        node->next = pCur;
        node = node->next;
        if(list1 != NULL) list1 = list1->next;
        if(list2 != NULL) list2 = list2->next;
    }
    return newList->next;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值