leetcode#2两数相加

1、题目

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

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

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

示例

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

2、涉及知识点(单链表)

为了在 C++ 中表示链表,需要有一个表示链表中单个结点的数据类型。不但需要包含要存储的 数据结构,还要有一个指向另一个相同类型结点的 指针

在这里插入图片描述

创建单链表步骤:
  1. 创建 头节点 head,并且将 当前结点 p 指向 头结点 (p = head)
  2. 创建下一个结点 q,当前结点p 的 下一结点为 q (p -> next = q)
  3. 当前结点p 后移一位 (p = p -> next)
// 假设每个结点将存储一个类型为 double 的数据项,则可以声明以下类型来存放结点:
    struct ListNode
    {
        double value;
        ListNode *next;
    };
// 创建 单链表
ListNode* head = new ListNode(0);  // 创建 头节点 ,初始化为0
ListNode* p = head;	声明一个中间变量(指针),指向头结点,用于遍历链表
p->value = 1;

ListNode *q= new ListNode; //创建 第二个节点
q->value = 2;
q->next = nullptr; // 链表第二个节点结束 
p->next = q; // 第一个节点指向第二个节点 

3、代码

  1. 获取两个链表所对应的长度
  2. 在较短的链表末尾补零
  3. 对齐相加考虑进位
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        ListNode *p = l1;
        ListNode *q = l2;
        ListNode *head = new ListNode(0); // 头节点, 保存结果的链表
        ListNode *r = head; //移动指针
        int sum = 0,temp = 0; //进位标志
        while(p != NULL || q != NULL){
            int x = (p != NULL) ? p ->val : 0;
            int y = (q != NULL) ? q ->val : 0;
            sum = x + y + temp;
            temp = sum / 10;
            r->next = new ListNode (sum % 10);
            r = r -> next;
            
            if (p != NULL) p = p -> next;
            if (q != NULL) q = q -> next;
            // 最后一位是否右进位,有则 新建 一个节点 1。
            if (temp == 1) r->next = new ListNode(1);
        }
        // 返回 从 head->next 地址后的所有数据;因为我们默认头里面存放 0, 
        // 所以这里不需要输出头节点,真正需要的数据从头节点的下一个开始

        return head->next; // 输出 [7,0,8]
        // return head; 输出 [0,7,0,8]

    }
};



参考:
1、https://blog.csdn.net/weixin_43930512/article/details/91382416
2、http://c.biancheng.net/view/1570.html
3、https://blog.csdn.net/zhengnianli/article/details/79320703?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值