这里我介绍一下我们学校的校园判题系统哦,
不喜别喷,喜欢就进入这个网站学习吧,我是
使用它一步一步学习C语言,逐渐学会了C语言
。使用这个网站最好使用谷歌浏览器吧,
广东技术师范大学在线判题网站http://www.gpnuacm.com/#/home
题目内容:
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
请你将两个数相加,并以相同形式返回一个表示和的链表。
你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例 1:
输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.
示例 2:
输入:l1 = [0], l2 = [0]
输出:[0]
提示:
每个链表中的节点数在范围 [1, 100] 内
0 <= Node.val <= 9
题目数据保证列表表示的数字不含前导零
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/add-two-numbers
代码:
/**
* 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) {
int len1 = 1, len2 = 1;//记录两条链的初始长度
ListNode* p1 = l1, * p2 = l2;//使用指针指向两条链表的表头
int num = 0;//保存链表的两数之和
bool flag = false;//后面关系到进位的操作
ListNode* l3 = new ListNode(0);//存放结果的l3链表
ListNode* p3 = l3;//指向l3的指针
while (p1->next != NULL)//记录l1长度
{
len1++;
p1 = p1->next;
} while (p2->next != NULL)//记录l2长度
{
len2++;
p2 = p2->next;
}
if (len1 > len2)
{
for (int i = 1; i <= len1 - len2; i++)
{
p2->next = new ListNode(0);
p2 = p2->next;
}
}
else
{
for (int i = 1; i <= len2 - len1; i++)
{
p1->next = new ListNode(0);
p1 = p1->next;
}
}
p1 = l1;//重新链接l1,l2的表头
p2 = l2;
while (p1 != NULL && p2 != NULL)
{
num = flag + p1->val + p2->val;//由后面可知,当满足超过10的时候就进位,flag的值就是true,就是1;当为false时就是0值
p3->next = new ListNode(num % 10);
flag = num >= 10 ? true : false;//判断进位,留给下一次 num = flag + p1->val + p2->val;使用
p3 = p3->next;
p1 = p1->next;
p2 = p2->next;
}
if (flag)//在最后仍存在进位的情况
{
p3->next = new ListNode(1);
p3 = p3->next;
}
return l3->next;
}
};
//本代码在力扣作者:chenlele ,的代码基础上修改和添加了一些注释