1、题目
给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。
如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
您可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例
输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807
2、涉及知识点(单链表)
为了在 C++ 中表示链表,需要有一个表示链表中单个结点的数据类型。不但需要包含要存储的 数据结构,还要有一个指向另一个相同类型结点的 指针。
创建单链表步骤:
- 创建 头节点 head,并且将 当前结点 p
指向
头结点(p = head)
- 创建下一个结点 q,当前结点p 的 下一结点为 q
(p -> next = q)
- 当前结点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、代码
- 获取两个链表所对应的长度
- 在较短的链表末尾补零
- 对齐相加考虑进位
/**
* 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