前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >【链表】LeetCode:2.两数相加

【链表】LeetCode:2.两数相加

作者头像
用户11396661
发布2024-12-09 15:05:20
发布2024-12-09 15:05:20
6800
代码可运行
举报
文章被收录于专栏:C++开发C++开发
运行总次数:0
代码可运行

前言: 数字可以在整形里面存,也可以在以字符串的形式存,也可以以链表的方式存,下面就看看链表存的两个数相加。 【LeetCode】链接:2. 两数相加 - 力扣(LeetCode) 喜欢的铁子可以点点关注,祝大家天天开心!

🏝1.问题:

问题描述: 给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。 请你将两个数相加,并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外,这两个数都不会以 0 开头。

示例:

示例 1:

代码语言:javascript
代码运行次数:0
复制
输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.

示例 2:

代码语言:javascript
代码运行次数:0
复制
输入:l1 = [0], l2 = [0]
输出:[0]

示例 3:

代码语言:javascript
代码运行次数:0
复制
输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
输出:[8,9,9,9,0,0,0,1]

提示:

  • 每个链表中的节点数在范围 [1, 100]
  • 0 <= Node.val <= 9
  • 题目数据保证列表表示的数字不含前导零

🏝2.问题分析:

我们只要把每一个对应位上的val相加就可以,然后把超过10的进位。如果有一条链表到达空了,那么我们就把他看成0,用另外一条链表的val值继续进行计算,最后到达两个链表都到达尾部。如果最后我们看最后还有没有进位,如果还超过10,我们就再申请一个节点,把1放进去。每次我们走一步,就申请一个节点,记录新的节点的头和尾,每次增加一个节点,tail尾节点就往后面跟着移动,最后返回head。

另外,我们还可以先申请一个黑头,这样我们就不要去对新的头节点为NULL情况的考虑,最后也只要返回head->next.

🏝3.实现代码:

代码语言:javascript
代码运行次数:0
复制
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
 typedef struct ListNode ListNode;
struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2) {
    ListNode* head,*tail;
    head=tail=(ListNode*)malloc(sizeof(ListNode));
    int carry=0;
    while(l1||l2)
    {
        int n1=l1?l1->val:0;
        int n2=l2?l2->val:0;
        int sum=n1+n2+carry;
        carry=sum/10;

        tail->next=(ListNode*)malloc(sizeof(ListNode));
        tail=tail->next;
        tail->next=NULL;
        tail->val=sum%10;
        if(l1)
            l1=l1->next;
        if(l2)
            l2=l2->next;
    }
    if(carry)
    {
        tail->next=(ListNode*)malloc(sizeof(ListNode));
        tail=tail->next;
        tail->val=1;
        tail->next=NULL;
    }
    return head->next;
}

总结: 这种类型的题目还有很多,我们多去思考多去练习,把这类型的题目摸索情况。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-05-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 🏝1.问题:
    • 示例:
  • 🏝2.问题分析:
  • 🏝3.实现代码:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档