【力扣 445】两数相加 II C++题解(链表+模拟+数学+头插法)

这篇具有很好参考价值的文章主要介绍了【力扣 445】两数相加 II C++题解(链表+模拟+数学+头插法)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

给你两个 非空 链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储一位数字。将这两数相加会返回一个新的链表。

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

示例1:

输入:l1 = [7,2,4,3], l2 = [5,6,4]
输出:[7,8,0,7]
示例2:

输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[8,0,7]
示例3:

输入:l1 = [0], l2 = [0]
输出:[0]

提示:

链表的长度范围为 [1, 100]
0 <= node.val <= 9
输入数据保证链表代表的数字无前导 0

进阶:如果输入链表不能翻转该如何解决?


思路

先将两个输入的链表反转,然后进行逐位相加,最后将结果再反转回来。让最低位在前,在相加过程中可以方便地处理进位问题。最后再将结果反转,使得最高位在前,满足题目要求。

在进行逐位相加的过程中,代码中定义了一个新的链表,用来存储相加的结果。在遍历输入的两个链表的过程中,每次取出两个链表当前节点的值相加,并加上新链表当前节点的值(用于接收上一位的进位),然后将相加的结果对10取余,得到的值赋给新链表的当前节点,将相加的结果除以10得到的值作为进位,如果进位不为0,则在新链表中添加一个新的节点,用于存储这个进位。

在处理完两个链表共有的部分后,如果两个链表的长度不等,还需要将较长的链表剩余的部分也加到新链表中。这部分的处理逻辑和前面相同,只是不再需要加两个链表的节点值,只需要加上新链表当前节点的值(接收上一位的进位)。

最后,将存储结果的新链表反转,并返回。文章来源地址https://www.toymoban.com/news/detail-820388.html


AC代码

/*
 * @lc app=leetcode.cn id=445 lang=cpp
 *
 * [445] 两数相加 II
 */

// @lc code=start
/**
 * 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 {
	ListNode* l3 = new ListNode();
	ListNode* p3 = l3;

   public:
	ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
		ListNode* rl1 = reverse(l1);
		ListNode* rl2 = reverse(l2);
		ListNode* p1 = rl1;
		ListNode* p2 = rl2;
		while (p1 != nullptr && p2 != nullptr) {
			if (p3->next == nullptr) {
				p3->next = new ListNode();
			}
			p3 = p3->next;
			int sum = p1->val + p2->val + p3->val;
			int s = sum % 10;
			int c = sum / 10;
			p3->val = s;
			if (c) {
				p3->next = new ListNode(c);
			}
			p1 = p1->next;
			p2 = p2->next;
		}
		move(p1);
		move(p2);
		l3 = l3->next;
		ListNode* rl3 = reverse(l3);
		return rl3;
	}

	ListNode* reverse(ListNode* l) {
		ListNode* rl = new ListNode();
		ListNode* p = l;
		ListNode* rp;
		while (p != nullptr) {
			rp = new ListNode(p->val);
			rp->next = rl->next;
			rl->next = rp;
			p = p->next;
		}
		rl = rl->next;
		return rl;
	}

	void move(ListNode* p) {
		while (p != nullptr) {
			if (p3->next == nullptr) {
				p3->next = new ListNode();
			}
			p3 = p3->next;
			int sum = p->val + p3->val;
			int s = sum % 10;
			int c = sum / 10;
			p3->val = s;
			if (c) {
				p3->next = new ListNode(c);
			}
			p = p->next;
		}
	}
};
// @lc code=end

到了这里,关于【力扣 445】两数相加 II C++题解(链表+模拟+数学+头插法)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据结构 | 链表】leetcode 2. 两数相加

    个人主页:兜里游客棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里游客棉花糖 原创 收录于专栏【LeetCode】 原题链接:点击直接跳转到该题目 给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位

    2024年02月05日
    浏览(52)
  • 【力扣】454. 四数相加 II

    【力扣】454. 四数相加 II 给你四个整数数组 nums1 、 nums2 、 nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足: 0 = i, j, k, l n nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0 示例 1: 输入:nums1 = [1,2], nums2 = [-2,-1], nums3 = [-1,2], nums4 = [0,2] 输出:2 解释: 两个元组如下

    2024年02月16日
    浏览(39)
  • 力扣142. 环形链表 II

    题目 给定一个链表的头节点head,返回链表开始入环的第一个节点。 如果链表无环,则返回null。 链接:142. 环形链表 II - 力扣(LeetCode) 题解 方法一:设置两个指针,一个指针指向链表头结点,一个指针指向判环时快慢指针相遇的位置,然后两个指针同时走,它们会在环的

    2024年02月16日
    浏览(65)
  • 【题解】删除有序链表中重复的元素-I、II

    题目链接:删除有序链表中重复的元素-I 解题思路1:利用set 遍历链表,将元素放入set中,利用set中元素不重复的特点,相当于重复元素只保留了一份,最后再遍历set,重构删除重复元素后的链表 代码如下: 解题思路2:遍历 如果下一个节点的值和本节点的值相同话,当前节

    2024年02月14日
    浏览(39)
  • 环形链表 II(力扣142)(快慢指针)

    142.环形链表—力扣 给定一个链表的头节点  head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到

    2023年04月25日
    浏览(40)
  • Leetcode每日一题:167. 两数之和 II - 输入有序数组(2023.7.8 C++)

    目录 167. 两数之和 II - 输入有序数组 题目描述: 实现代码与解析: 暴力(超时) 双指针 原理思路: 二分 原理思路:         给你一个下标从  1  开始的整数数组  numbers  ,该数组已按   非递减顺序排列   ,请你从数组中找出满足相加之和等于目标数  target  的两

    2024年02月13日
    浏览(47)
  • 「双指针」删除排序链表中的重复元素 II(力扣第82题)

    本题为1月15日力扣每日一题 题目来源:力扣第82题 题目tag: 链表 双指针 给定一个已排序的链表的头head,删除原始链表中所有重复数字的节点,只留下不同的数字。返回已排序的链表。 示例 1 输入: 输出: 示例 2 输入: 输出: 链表中节点数目在范围$ [0,300] $内 $ -100 leq Nod

    2024年02月01日
    浏览(49)
  • 力扣题解24. 两两交换链表中的节点(图解递归和双指针)

    题目描述: 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。 示例 1: 示例 2: 示例 3: 提示: 链表中节点的数目在范围 [0, 100] 内 0 = Node.val = 100 方法一:递归 代码解析 这

    2024年01月15日
    浏览(47)
  • C++刷题第六天 454.四数相加II 383. 赎金信 15. 三数之和 18. 四数之和

    给你四个整数数组 nums1、nums2、nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足: 0 = i, j, k, l n nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0 这个题目是哈希表应用的经典题目。 如果用暴力解法,四个数组,那肯定要四层for循环嵌套,时间复杂度就是n的四次方

    2024年02月13日
    浏览(46)
  • 力扣hot100 环形链表 快慢指针 哈希 数学公式

    Problem: 142. 环形链表 II 👨‍🏫 参考题解 ⏰ 时间复杂度: O ( n ) O(n) O ( n ) 🌎 空间复杂度: O ( 1 ) O(1) O ( 1 )

    2024年01月23日
    浏览(70)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包