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变量