博客
关于我
LeetCode Add Two Numbers
阅读量:802 次
发布时间:2023-01-31

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

singly-linked-list: 模拟数字加法

在现实的编程练习中,我们有时会遇到需要通过模拟手动加法来完成算法实现的情况。这种方法通常用于处理类似数字相加的问题,尤其是在编写测试用例或练习数据操作时特别实用。以下,我将详细介绍如何使用singly-linked list(单向链表)的方式来模拟数字的加法,并处理可能的进位问题。


模拟数字加法的逻辑

输入

我们的输入是两个由数字节点组成的链表,每个节点包含一个数字值,还有一个指向下一个节点的指针。需要注意的是,这些节点的数字是按逆序存储的。例如,数字42被表示为2 -> 4,也就是4节点指向2节点。

制作链表

比如,输入:

(2 -> 4 -> 3) + (5 -> 6 -> 4)

我们可以创建以下链表结构:

  • 链表A:3 -> 2 -> 4
  • 链表B:4 -> 6 -> 5

加法过程

我们可以从链表的第一个节点(末尾)开始加起来,每一步计算当前节点的值之和,再处理可能的进位。具体步骤如下:

  • 初始状态:假设两个链表都有节点,我们从两者当前节点的值开始相加。
  • 创建新的节点:将相加的结果存储到新的节点中。
  • 处理进位:如果结果大于等于10,将进位值设为结果整除10的商,并将结果取余数存储到新的节点中。
  • 移动指针:将当前链表的指针向前移动一位,同时注意处理可能提前结尾的情况。
  • 完整的加法逻辑

    class Solution {public:    struct ListNode {        int val;        ListNode *next;        ListNode(int x) : val(x), next(NULL) {}    };    ListNode *addTwoNumbers(ListNode *l1, ListNode *l2) {        if (l1 == NULL && l2 == NULL) return NULL;        ListNode *head = NULL;        ListNode *pre = NULL;        int carry = 0;        while (l1 && l2) {            int sum = l1->val + l2->val + carry;            carry = sum / 10;            int val = sum % 10;            ListNode *node = new ListNode(val);            if (head == NULL) {                head = node;            } else {                pre->next = node;            }            pre = node;            l1 = l1->next;            l2 = l2->next;        }        // 处理可能剩下的节点        while (l1) {            int sum = l1->val + carry;            carry = sum / 10;            int val = sum % 10;            ListNode *node = new ListNode(val);            if (head == NULL) {                head = node;            } else {                pre->next = node;            }            pre = node;            l1 = l1->next;        }        while (l2) {            int sum = l2->val + carry;            carry = sum / 10;            int val = sum % 10;            ListNode *node = new ListNode(val);            if (head == NULL) {                head = node;            } else {                pre->next = node;            }            pre = node;            l2 = l2->next;        }        // 处理最后的进位        if (carry > 0) {            ListNode *node = new ListNode(carry);            if (head == NULL) {                head = node;            } else {                pre->next = node;            }        }        return head;    }}

    总结

    通过上述算法,我们完整地完成了两个单向链表的加法操作,包括处理进位等问题。这种方法能够确保我们能正确地将两个数字相加,并以链表的形式返回结果。

    操作流程总结

  • 初始化:检查两个链表的头节点,如果都为空则返回空链表。
  • 循环加法:从两个链表的尾部节点开始逐位相加,直到至少有一个链表的节点耗尽。
  • 创建新节点:将当前相加值存储到新的链表节点中,并更新进位值。
  • 处理剩余节点:在当前链表有节点剩余时,继续加法并加上可能的进位。
  • 处理最终进位:如果最后一次加法产生了进位,将其存储到新的节点中。
  • 这种方法确保了我们能够正确地将两个数字相加,并返回合并后的结果。

    转载地址:http://jogyk.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置TCP代理指南
    查看>>
    Nginx配置——不记录指定文件类型日志
    查看>>
    nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    nginx配置全解
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置后台网关映射路径
    查看>>
    nginx配置域名和ip同时访问、开放多端口
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>