leetcode_2816. 翻倍以链表形式表示的数字

2816. 翻倍以链表形式表示的数字 - 力扣(LeetCode)

搜先看到这个题目 链表的节点那么多 已经远超longlong能够表示的范围 那么暴力解题 肯定是不可以的了

我们可以想到 乘法运算中 就是从低位到高位进行计算 刚开始 我想先反转链表 然后在计算 然后在进行反转 得到一个新的结果 但是这样子耗费时间太多了

然后我还想到可以先把链表中的数先组成一个数 然后在进行计算 但是这个数远超longlong能表示的范围

此时 我们想到 链表的前一个节点的数与后一个节点的数有关 那么我们可以利用递归回溯来解决这一个问题

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    void doDouble(ListNode* head, int* cap) {
        if (head == NULL) {
            *cap = 0;
            return;
        }
        int val;
        doDouble(head->next, &val);
        head->val = head->val * 2 + val;
        *cap = head->val / 10;
        head->val %= 10;
    }

    ListNode* doubleIt(ListNode* head) {
        int val;
        doDouble(head, &val);
        return val == 0 ? head : new ListNode(val, head);
    }
};

其中

cap是指向下一个节点的val的指针 在递归过程中 使用cap来看是否需要进位 并且将值返还给val变量

相关推荐
L~river4 分钟前
SQL刷题快速入门(二)
数据库·sql·mysql·算法·笔试·刷题
廖显东-ShirDon 讲编程17 分钟前
《零基础Go语言算法实战》【题目 2-3】函数错误排查
算法·程序员·go语言·web编程·go web
羊小猪~~1 小时前
数据结构C语言描述11(图文结合)--二叉搜索树(BST树)的实现(数据采用KV存储形式进行封装)
c语言·开发语言·数据结构·c++·学习·考研·算法
阿杰学编程1 小时前
3、Go中的注释
c++·算法·golang
Catherinemin1 小时前
剑指Offer|LCR 027.回文链表
数据结构·链表
青い月の魔女2 小时前
数据结构初阶---排序
开发语言·数据结构·笔记·学习·算法·排序算法
594h23 小时前
蓝桥杯 第十五届 研究生组 B题 召唤数学精灵
c++·算法·蓝桥杯
冠位观测者4 小时前
【Leetcode 热题 100】739. 每日温度
数据结构·算法·leetcode
yanglee05 小时前
L4-Prompt-Delta
人工智能·算法·语言模型·prompt