Leetcode306累加数(递归解决)

简介: Leetcode306累加数(递归解决)
/**
 * @param {string} num
 * @return {boolean}
 */
var isAdditiveNumber = function(num) {
    let flag = false
var addStrings = function(num1, num2) {
    let arr1 = num1.split('').map(item=>{return Number(item)})
    let arr2 = num2.split('').map(item=>{return Number(item)})
    let jin = 0
    let str = ''
    while(arr1.length || arr2.length || jin){
        let number1 = arr1.pop() || 0
        let number2 = arr2.pop() || 0
        str =(jin + number2 + number1)%10 + str
        jin = Math.floor((jin + number2 + number1)/10) 
    }
    return str

};
    function dfs(pre,curr,rest){
        if(pre.length >1 && pre[0] === "0"){
            return
        }
        if(curr.length >1 && curr[0] === "0"){
            return
        }
        if(rest === ''){
            flag = true
            return
        }
        let total = addStrings(pre,curr)
        if(rest.length < total.length){
            return
        }
        let next = rest.substring(0,total.length)
        if(next === total){
            dfs(curr,next,rest.substring(total.length))
        }
        
    }

    // i是第一个字符串尾部对应的索引
    // j是第二个字符串尾部对应的索引
    for(let i=0;i<num.length;i++){
        // TODO
        // 进一步,限制
        // 进一步
        // 搞定这个i j的关系
        for(let j=i+1;j-i<=num.length -j;j++){
            if(num.substring(j+1)){
            dfs(num.substring(0,i+1),num.substring(i+1,j+1),num.substring(1+j))
            }
        }
    }
    return flag

};

这道题讲道理写了这么多行代码,用了两个中难度的解决办法,也算是个复杂题了吧?

解题思路:
i和j分别表示第一个数的截至位置和第二个数的截至位置。
这样就算是确定了开头的两个数字,此外还需要一个函数用来计算两个字符串的和。剩下的就是修一下边边角角,对于一些特殊条件的过滤了。上面的写法还有一些优化空间,不过今天没空搞了,有不理解的可以留言交流下。

相关文章
|
6月前
|
机器学习/深度学习 存储 算法
LeetCode 题目 95:从递归到动态规划实现 不同的二叉搜索树 II
LeetCode 题目 95:从递归到动态规划实现 不同的二叉搜索树 II
|
4月前
|
存储
LeetCode------递归(爬楼梯)
这篇文章通过LeetCode上的"爬楼梯"问题介绍了递归的基本概念和实现方法,包括递归公式的推导、基本递归实现、使用备忘录优化以避免重复计算,以及自底向上的迭代方法来提高效率。
LeetCode------递归(爬楼梯)
|
6月前
|
存储 算法 数据挖掘
python5种算法模拟螺旋、分层填充、递归、迭代、分治实现螺旋矩阵ll【力扣题59】
python5种算法模拟螺旋、分层填充、递归、迭代、分治实现螺旋矩阵ll【力扣题59】
|
6月前
|
机器学习/深度学习 存储 算法
Python5种算法回溯+剪枝、字典序、递归交换、计数回溯、迭代法 实现全排列ll【力扣题47】
Python5种算法回溯+剪枝、字典序、递归交换、计数回溯、迭代法 实现全排列ll【力扣题47】
|
6月前
|
存储 机器学习/深度学习 算法
python 五种算法转置后翻转、层次旋转、递归分块、一次性旋转、环状替换 实现旋转图像【力扣题48】
python 五种算法转置后翻转、层次旋转、递归分块、一次性旋转、环状替换 实现旋转图像【力扣题48】
|
6月前
|
存储 算法 数据可视化
力扣156题最全解法:如何上下翻转二叉树(递归与迭代方法详解,附图解)
力扣156题最全解法:如何上下翻转二叉树(递归与迭代方法详解,附图解)
|
6月前
|
存储 算法 数据可视化
LeetCode 题目 96:从动态规划、递归到卡塔兰数实现不同的二叉搜索树
LeetCode 题目 96:从动态规划、递归到卡塔兰数实现不同的二叉搜索树
|
6月前
|
存储 算法 数据可视化
LeetCode 131题详解:高效分割回文串的递归与动态规划方法
LeetCode 131题详解:高效分割回文串的递归与动态规划方法
|
6月前
|
SQL 算法 数据可视化
LeetCode题目92:反转链表ll 【python 递归与迭代方法全解析】
LeetCode题目92:反转链表ll 【python 递归与迭代方法全解析】
|
6月前
|
存储 传感器 算法
LeetCode题目89:格雷码 递归、迭代及位操作在数组合并中的应用
LeetCode题目89:格雷码 递归、迭代及位操作在数组合并中的应用