91. 解码方法

递归法:超时了

从字符串的后面向前计算,每一次递归都缩小子集

cs 复制代码
public class Solution {
    public int NumDecodings(string s) {
        return RecursiveAdd(s, s.Length - 1);
    }

    public int RecursiveAdd(string s, int index) {
        // 已经到最后一个元素
        if(index < 0)
        {
            return 1;
        }

        int count = 0;
        if(s[index] != '0')
        {
            // 将这个元素解码为[1,9]内的数字
            count = RecursiveAdd(s, index - 1);
        }

        // 最后一个数字
        if(index == 0)
        {
            return count;
        }

        // 将元素解码为两位数
        int prevIndex = index - 1;
        if((s[prevIndex] == '1') || (s[prevIndex] == '2' && s[index] <= '6'))
        {
            count += RecursiveAdd(s, index - 2);
        }
        return count;
    }
}

参考动态规划 :

从字符串的前面向后计算

cs 复制代码
public class Solution {
    public int NumDecodings(string s) {
        int len = s.Length;
        // a = f[i - 2], b = f[i - 1], c = f[i]
        int a = 0, b = 1, c = 0;
        for(int i = 1; i <= len; i++)
        {
            c = 0;
            if(s[i - 1] != '0')
            {
                c += b;
            }
            if(i > 1 && s[i - 2] != '0' && ((s[i - 2] - '0') * 10 + (s[i - 1] - '0') <= 26))
            {
                c += a;
            }
            a = b;
            b = c;
        }
        return c;
    }
}

感想:

这两种解法,刚好反映了,递归与动态规划的关系,

递归

n -> n - 1-> ...> 0

-> n - 2> ...> 0

动态规划

0 ->1->...>n

相关推荐
我是一只鱼02236 分钟前
LeetCode算法题 (反转链表)Day17!!!C/C++
数据结构·c++·算法·leetcode·链表
LuckyLay27 分钟前
LeetCode算法题(Go语言实现)_62
算法·leetcode·职场和发展
元亓亓亓28 分钟前
LeetCode热题100--54.螺旋矩阵--中等
算法·leetcode·矩阵
菜鸟破茧计划32 分钟前
C++ 算法学习之旅:从入门到精通的秘籍
c++·学习·算法
灏瀚星空44 分钟前
PyTorch 入门与核心概念详解:从基础到实战问题解决
人工智能·pytorch·python·深度学习·算法·机器学习
czhaii1 小时前
单片机自动排列上料控制程序 下
算法
石去皿2 小时前
C++ 中的 `it->second` 和 `it.second`:迭代器与对象访问的微妙区别
开发语言·c++·算法·leetcode
adam_life2 小时前
2025年3月电子学会等级考试五级题——4、收费站在哪里
算法·五级·电子学会等级考试·递归,深搜,回溯·multiset、vector
数据与人工智能律师2 小时前
私服与外挂:刑事法律风险的深度剖析
大数据·人工智能·算法·云计算·区块链
David Bates2 小时前
代码随想录第39天:单调栈
python·算法·单调栈