力扣HOT100(28)两数相加

题目说:数字是逆序存储在链表中的

  • 示例 1:链表 2→4→3 代表的数字是 342
  • 也就是:链表头是个位,第二个节点是十位,第三个是百位,以此类推

⚠️ 这反而是好事!因为我们平时手写加法,就是从个位开始加,正好对应链表从左到右遍历的顺序,不用反转链表,直接逐位相加就行。

  • 两个指针分别遍历两个链表,对应两个数的当前位

  • 用一个变量carry记录进位

  • 逐位相加,计算当前位的值和新的进位

  • 用已经会的虚拟头 + 尾指针 ,把结果节点拼接到新链表上

    cpp 复制代码
    /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     ListNode *next;
     *     ListNode() : val(0), next(nullptr) {}
     *     ListNode(int x) : val(x), next(nullptr) {}
     *     ListNode(int x, ListNode *next) : val(x), next(next) {}
     * };
     */
    class Solution {
    public:
        ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    
    
            //虚拟头 新链表存结果
            ListNode * dhead = new ListNode(-1);
            ListNode * tail = dhead;
            int carry = 0;
    
       while (l1 != nullptr || l2 != nullptr || carry != 0){//如果还有进位还有值的话还要加的下一位 因此不能结束。
                //如果给的链表为空 直接记为零
                int n1 = l1 ? l1->val : 0;
                int n2 = l2 ? l2->val : 0;
    
                //每位的和等于对应链表的和+进位
                int sum = n1 + n2 + carry;
                
                carry = (sum)/10;
                
                tail->next = new ListNode((sum)%10);//类型转换
                
                tail = tail->next;
                if(l1) //如果为空 就不能移位
                l1 = l1->next;
    
                if(l2)
                l2 = l2->next;
               
            }
    
    
    
            return dhead->next;
        }
    };
相关推荐
一只齐刘海的猫12 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏11112 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
IronMurphy13 小时前
【算法五十七】146. LRU 缓存
算法·缓存
文艺倾年14 小时前
【强化学习】强化学习基本概念,20W字总结(一)
人工智能·python·语言模型·自然语言处理·面试·职场和发展·大模型
凌波粒14 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle14 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂14 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠14 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
兰令水15 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
临沂堇15 小时前
刷题日志 | Leetcode Hot 100 哈希
算法·leetcode·哈希算法