博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2.两数相加(Add Two Numbers) C++
阅读量:6282 次
发布时间:2019-06-22

本文共 1466 字,大约阅读时间需要 4 分钟。

第一想法是顺着题目的原因,将两链表分别转化为一个数字,再将数字相加,然后把结果转化为字符串,存到答案链表中。但是数据太大会溢出!

所以,要在计算一对数字的过程当中直接存储一个结果,注意结果大于9时进位,删去最终链表的最后一个节点。

/** * Definition for singly-linked list. * struct ListNode { *     int val; *     ListNode *next; *     ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {public:    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {        int carry=0;        int x,y,z;        ListNode* head = new ListNode(-1);        ListNode* use = new ListNode(-1);        ListNode* t = new ListNode(-1);        head->next = t;        while(l1 || l2)        {            if(!l1)            {                x = 0;            }else x = l1->val;            if(!l2)            {                y = 0;            }else y = l2->val;            z = x + y + carry;            carry = 0;            if(z>9)            {                carry = 1;                z = z-10;            }            t->val = z;            t->next = new ListNode(-1);            use = t;            t = t->next;            t->next = NULL;            if(l1)            {                l1 = l1->next;            }            if(l2)            {                l2 = l2->next;            }        }        if(carry)        {            t->val = carry;            t->next = new ListNode(-1);            use = t;            t = t->next;            t->next = NULL;        }        t = head->next;        use->next = NULL;        return t;    }};

 

转载于:https://www.cnblogs.com/tornado549/p/9937709.html

你可能感兴趣的文章
Go 时间交并集小工具
查看>>
iOS 多线程总结
查看>>
webpack是如何实现前端模块化的
查看>>
TCP的三次握手四次挥手
查看>>
关于redis的几件小事(六)redis的持久化
查看>>
package.json
查看>>
webpack4+babel7+eslint+editorconfig+react-hot-loader 搭建react开发环境
查看>>
Maven 插件
查看>>
初探Angular6.x---进入用户编辑模块
查看>>
计算机基础知识复习
查看>>
【前端词典】实现 Canvas 下雪背景引发的性能思考
查看>>
大佬是怎么思考设计MySQL优化方案的?
查看>>
<三体> 给岁月以文明, 给时光以生命
查看>>
Android开发 - 掌握ConstraintLayout(九)分组(Group)
查看>>
springboot+logback日志异步数据库
查看>>
Typescript教程之函数
查看>>
Android 高效安全加载图片
查看>>
vue中数组变动不被监测问题
查看>>
3.31
查看>>
类对象定义 二
查看>>