【Golang】LeetCode 2. 两数相加

2. 两数相加

题目描述

思路

这道题相当于在链表上实现两数相加,还是比较简单的,尤其是题目中一开始给我们的链表就是已经被翻转好的链表,并且最终要返回的也是被翻转后的结果(其实要是没有反转也不难,只要调用一下反转链表的模版就解决了)。

我们不使用额外的链表存储结果,而是直接将结果保存到l1链表当中。

一开始,我们新建一个整型变量cnt := 0,用于保存进位(它的值只可能是0 / 1)。新建三个指针,分别是p, q, prev := l1, l2, l1p, q指针没什么好说的,我们需要用他俩来对链表进行遍历;值得关注的是prev指针,它的作用是记录p节点的前序节点(一开始也可以被初始化为(*ListNode)(nil),但是太麻烦了,索性直接使用l1)。

接下来我们开始对链表进行遍历,每次计算curr := p.Val + q.Val + cnt的值,然后取当前位的值curr = curr % 10以及进位值cnt = cnt / 10,并同时向后移动两个节点。特别需要注意的是,移动两个节点之前,需要先设置prev = p,也就是让prev指向移动p之后的前序节点。

基于p, q对链表进行遍历之后,如果链表不等长,那么p / q会停留在中间的某个节点上。如果l1链表更长,那么我们继续对p进行处理即可。否则,我们先令prev.Next, p = q, q,也就是将当前q节点及其之后的节点拼接到prev之后(此时p == nil),然后令p指向当前的q,以继续对l1所在的链表进行处理。

基于上面这个操作,接下来我们对p的处理是统一的。我们对p进行后移,条件是p != nil && cnt != 0。此时q == nil,在计算当前的和时,只需要计算curr = p.Val + cnt即可,之后维护cntcurr,然后维护prevp后移即可。

最后,如果cnt != 0,就说明在最后一位有进位,当前指向最后一个节点的指针是prev,我们令prev.Next = new(ListNode)并令这个节点的值为1即可完成本题。

基于以上思路,我们写代码来解决问题。

Golang 题解

go 复制代码
/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
    cnt := 0
    p, q, prev := l1, l2, l1
    for p != nil && q != nil {
        curr := p.Val + q.Val + cnt
        cnt = curr / 10
        curr = curr % 10

        p.Val = curr

        prev = p
        p = p.Next
        q = q.Next
    }

    if q != nil {
        prev.Next = q
        p = q
    }

    for p != nil && cnt != 0 {
        curr := p.Val + cnt
        cnt = curr / 10
        curr %= 10
        
        p.Val = curr
        prev = p
        p = p.Next
    }

    if cnt != 0 {
        prev.Next = new(ListNode)
        prev.Next.Val = 1
    }

    return l1
}
相关推荐
Rabbit_QL1 天前
【水印添加工具】从零设计一个工程级 Python 图片水印工具:WaterMask 架构与实现
开发语言·python
天“码”行空1 天前
简化Lambda——方法引用
java·开发语言
让我上个超影吧1 天前
【力扣26&80】删除有序数组中的重复项
算法·leetcode
z20348315201 天前
C++对象布局
开发语言·c++
Beginner x_u1 天前
如何解释JavaScript 中 this 的值?
开发语言·前端·javascript·this 指针
java1234_小锋1 天前
Java线程之间是如何通信的?
java·开发语言
张张努力变强1 天前
C++ Date日期类的设计与实现全解析
java·开发语言·c++·算法
feifeigo1231 天前
基于EM算法的混合Copula MATLAB实现
开发语言·算法·matlab
LYS_06181 天前
RM赛事C型板九轴IMU解算(4)(卡尔曼滤波)
c语言·开发语言·前端·卡尔曼滤波
漫随流水1 天前
leetcode回溯算法(78.子集)
数据结构·算法·leetcode·回溯算法