首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    撬动offer:两个长字符串数字相加

    编写一个函数实现这两个数的二进制字符串相加。考虑都是无符号数字相加。...题目变种 有两个字符串分别如下: String a = "1879987637894818799876378948"; String b = "176898"; 字符串里的数字是0到9的任意一个数字字符...编写一个函数实现这两个十进制字符串的相加。考虑都是无符号数字相加。...那么就不可以使用简单的数字相加的方法了,因为a或者b早就溢出了,Integer或者Long已经无法表示a或b这两个数值了。这时候要怎么计算呢?...回想一下老师教的数字是怎么相加,其实就是从数字的最右边的最后一位开始(就是个位开始计算),将两个对应的位进行相加,对于十进制,如果相加数字大于等于10,就往前进一位。就这样教计算机进行计算即可。

    1K20

    大数相加

    “ 都那么大了,还相加” ---- 题目: 给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。...如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。 您可以假设除了数字 0 之外,这两个数都不会以 0 开头。...输入:(2 -> 4 -> 3) + (5 -> 6 -> 4) 输出:7 -> 0 -> 8 原因:342 + 465 = 807 题解1: 思路: 两个大数是用链表逆序存储的,所以是从头遍历相加...每一位的相加会是三个值的相加,加数(a)、被加数(b)和来自低位的进位(c) 从最低位开始相加,用一个临时变量存储来自低位的进位 最低位的加数和被加数最大为9,进位为最大为1,相加后最低位的值最大为

    1K10

    两数相加

    它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。 请你将两个数相加,并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外,这两个数都不会以 0 开头。...{} }; class Solution { public: ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) { //用来存放相加结果的链表...p1->next : new ListNode();//如果l1的位数较少,那么就在他最高位前面补上0,方便与l2进行相加操作 p2 = p2->next != NULL ?...p2->next : new ListNode(); //生成head链表新的一个节点,用来存放当前遍历得到的l1+l2的val值 //例如第一次循环获得的是l1和l2的十位上数字相加之和...//这里还要加上cur指向当前节点的val值/10,是因为 //例如:第一个两个整数个位相加得到的val=12,那么此时要进位,这里是尾插法,cur的next新节点存放的值是十位的值,因此12

    74610

    两数相加

    两数相加 题目描述 给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。...如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。 您可以假设除了数字 0 之外,这两个数都不会以 0 开头。...示意图 对两数相加的可视化:342 + 465 = 807,每个结点都包含一个数字,并且数字按位逆序存储。 就像在纸上计算两个数字一样,首先从最低有效位也就是 链表 l1 和 l2 的头部开始相加。...由于每位数字都应当处于 0~9 的范围内,所以在计算两个数字的和时可能会出现”溢出“。...进位 carry 必定是0或1,这是因为两个数字相加(考虑到进位)可能出现的最大和为 9 + 9 + 1 = 19。

    95420
    领券