广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++如何实现算法两个数字相加
  • 453
分享到

C++如何实现算法两个数字相加

2023-06-20 15:06:56 453人浏览 薄情痞子
摘要

这篇文章主要为大家展示了“c++如何实现算法两个数字相加”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C++如何实现算法两个数字相加”这篇文章吧。Add Two Numbers 两个数字相加Yo

这篇文章主要为大家展示了“c++如何实现算法两个数字相加”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C++如何实现算法两个数字相加”这篇文章吧。

Add Two Numbers 两个数字相加

You have two numbers represented by a linked list, where each node contains a single digit. The digits are stored in reverse order, such that the 1's digit is at the head of the list. Write a function that adds the two numbers and returns the sum as a linked list.
EXAMPLE
Input: (7-> 1 -> 6) + (5 -> 9 -> 2).That is, 617 + 295.
Output: 2 -> 1 -> 9.That is, 912.
FOLLOW UP
Suppose the digits are stored in forward order. Repeat the above problem.
EXAMPLE
Input: (6 -> 1 -> 7) + (2 -> 9 -> 5).That is, 617 + 295.
Output: 9 -> 1 -> 2.That is, 912.

LeetCode上的原题,请参考另一篇文档Add Two Numbers 两个数字相加。

跟那道LeetCode有所不同的是,这道题还有个Follow Up,把链表存的数字方向变了,原来是表头存最低位,现在是表头存最高位。既然是翻转了链表,那么一种直接的解法是把两个输入链表都各自翻转一下,然后用之前的方法相加完成,再把得到的结果翻转一次,就是结果了,翻转链表的方法可以参考另一篇文档Reverse Linked List 倒置链表。代码如下:

解法一:

// Follow upclass Solution {public:    ListNode *addTwoNumbers(ListNode *l1, ListNode *l2) {        ListNode *dummy = new ListNode(-1);        ListNode *cur = dummy;        int carry = 0;        l1 = reverseList(l1);        l2 = reverseList(l2);        while (l1 || l2) {            int n1 = l1 ? l1->val : 0;            int n2 = l2 ? l2->val : 0;            int sum = n1 + n2 + carry;            carry = sum / 10;            cur->next = new ListNode(sum % 10);            cur = cur->next;            if (l1) l1 = l1->next;            if (l2) l2 = l2->next;        }        if (carry) cur->next = new ListNode(1);        return reverseList(dummy->next);    }    ListNode *reverseList(ListNode *head) {        if (!head) return head;        ListNode *dummy = new ListNode(-1);        dummy->next = head;        ListNode *cur = head;        while (cur->next) {            ListNode *tmp = cur->next;            cur->next = tmp->next;            tmp->next = dummy->next;            dummy->next = tmp;        }        return dummy->next;    }};

如果我们不采用翻转链表的方法该怎么做呢,这就比较复杂了。首先我们要县分别计算出两个链表的长度,然后给稍短一点的链表前面补0,补到和另一个链表相同的长度。由于要从低位开始相加,而低位是链表的末尾,所以我们采用递归来处理,先遍历到链表的末尾,然后从后面相加,进位标示符carry用的是引用,这样保证了再递归回溯时值可以正确传递,每次计算的节点后面接上上一次回溯的节点,直到回到首节点完成递归。最后还是处理最高位的进位问题。代码如下:

解法二:

// Follow upclass Solution {public:    ListNode *addTwoNumbers(ListNode *l1, ListNode *l2) {        int n1 = 0, n2 = 0, carry = 0;;        n1 = getLength(l1);        n2 = getLength(l2);        if (n1 > n2) l2 = padList(l2, n1 - n2);        if (n2 > n1) l1 = padList(l1, n2 - n1);        ListNode *res = addTwoNumbersDFS(l1, l2, carry);        if (carry == 1) {            ListNode *tmp = new ListNode(1);            tmp->next = res;            res = tmp;        }        return res;    }    ListNode *addTwoNumbersDFS(ListNode *l1, ListNode *l2, int &carry) {        if (!l1 && !l2) return NULL;        ListNode *list = addTwoNumbersDFS(l1->next, l2->next, carry);        int sum = l1->val + l2->val + carry;        ListNode *res = new ListNode(sum % 10);        res->next = list;        carry = sum / 10;        return res;    }    ListNode *padList(ListNode *list, int len) {        ListNode *dummy = new ListNode(-1);        ListNode *cur = dummy;        for (int i = 0; i < len; ++i) {            cur->next = new ListNode(0);            cur = cur->next;        }        cur->next = list;        return dummy->next;    }    int getLength(ListNode *list) {        ListNode *cur = list;        int res = 0;        while (cur) {            ++res;            cur = cur->next;        }        return res;    }};

以上是“C++如何实现算法两个数字相加”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网其他教程频道!

--结束END--

本文标题: C++如何实现算法两个数字相加

本文链接: https://www.lsjlt.com/news/297629.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++如何实现算法两个数字相加
    这篇文章主要为大家展示了“C++如何实现算法两个数字相加”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C++如何实现算法两个数字相加”这篇文章吧。Add Two Numbers 两个数字相加Yo...
    99+
    2023-06-20
  • C++实现算法两个数字相加详解
    Add Two Numbers 两个数字相加 You have two numbers represented by a linked list, where each n...
    99+
    2022-11-12
  • C++如何实现LeetCode两个数字相加
    这篇文章将为大家详细讲解有关C++如何实现LeetCode两个数字相加,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。[LeetCode] 2. Add Two Numbers 两个数字相加You are ...
    99+
    2023-06-20
  • C++实现LeetCode(2.两个数字相加)
    [LeetCode] 2. Add Two Numbers 两个数字相加 You are given two non-empty linked lists rep...
    99+
    2022-11-12
  • LeetCode如何实现两个数字相加
    小编给大家分享一下LeetCode如何实现两个数字相加,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!题目给定两个非空链表来表示两个非负整数。位数按照逆序方式存储,...
    99+
    2023-06-19
  • php如何实现两个数字相加
    这篇“php如何实现两个数字相加”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“php如何实现两个数字相加”文章吧。php实现...
    99+
    2023-06-29
  • php怎么实现两个数字相加
    本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑php实现两个数字相加1、使用“+”加法运算符“+”运算符就是用于加法计算的。示例:<php $a = -100; $b = 70; ec...
    99+
    2019-04-20
    php 两数字相加
  • C语言怎么实现两个整数相加
    这篇文章主要介绍“C语言怎么实现两个整数相加”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C语言怎么实现两个整数相加”文章能帮助大家解决问题。使用 scanf() 来接收输入, printf() 与...
    99+
    2023-06-17
  • Android实现两个数相加功能
    本文实例为大家分享了Android实现两个数相加的具体代码,供大家参考,具体内容如下 要实现如图所示的加法计算器的话,还是比较简单的,下面直接上demo,有不懂的可以留言交流。...
    99+
    2022-06-06
    Android
  • C++如何实现两数相除
    本篇内容介绍了“C++如何实现两数相除”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Divide Two Integers 两数相除Give...
    99+
    2023-06-19
  • C#算法如何实现两数之和
    小编给大家分享一下C#算法如何实现两数之和,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!题目给定一个整数数组 nums和一个目标值 targe...
    99+
    2023-06-26
  • Python中两个列表数字“相加”的4种方法
    最近我在用Python处理数据时,需要将列表数据相加实现“累积”效果的。需要注意,我这里所说的列表相加,并非是下面这种“列表元素相加”的情况。 list_1 = [1, 2, 3]list_2 = [4, 5, 6]print(list_1...
    99+
    2023-08-31
    python numpy 开发语言
  • php如何实现两个最大值相加
    这篇文章主要介绍“php如何实现两个最大值相加”,在日常操作中,相信很多人在php如何实现两个最大值相加问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php如何实现两个最大值相加”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-30
  • QT如何实现将两个时间相加
    本篇内容介绍了“QT如何实现将两个时间相加”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!标志位首先介绍实现的这两个函数:void setTr...
    99+
    2023-07-02
  • java中两个字符串的拼接、整数相加和浮点数相加实现代码
    编写一个Java应用程序,从键盘读取用户输入两个字符串,并重载3个函数分别实现这两个字符串的拼接、整数相加和浮点数相加,并输出结果。要进行异常处理,对输入的不符合要求的字符串提示给用...
    99+
    2022-11-12
  • python3中如何实现两数相加
    这篇文章主要介绍python3中如何实现两数相加,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!两数相加给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 ...
    99+
    2023-06-14
  • python如何实现数组元素两两相加
    目录数组元素两两相加求数组中两两相加等于20的组合(Python实现)题目解析Python实现数组元素两两相加 count = 0 c2 = [] for i in range(le...
    99+
    2022-11-11
  • php如何实现两个数相除
    这篇文章主要介绍了php如何实现两个数相除的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇php如何实现两个数相除文章都会有所收获,下面我们一起来看看吧。在PHP中,除法运算使用斜杠(/)进行表示,例如12/3就...
    99+
    2023-07-06
  • php如何实现两个数相乘
    PHP是一种常用的服务器端脚本语言,可以用于开发各种 Web 应用程序。本文将介绍如何使用 PHP 实现两个数相乘的功能。在 PHP 中,可以使用 "*" 运算符来进行乘法计算。下面是一个简单的 PHP 程序,演示如何将...
    99+
    2023-05-14
    php
  • 怎么在java中实现两个大数相加
    怎么在java中实现两个大数相加?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。代码如下:public class BigIntAdd {priva...
    99+
    2023-05-30
    java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作