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

相关推荐
古希腊掌管学习的神22 分钟前
[搜广推]王树森推荐系统笔记——曝光过滤 & Bloom Filter
算法·推荐算法
qystca23 分钟前
洛谷 P1706 全排列问题 C语言
算法
浊酒南街28 分钟前
决策树(理论知识1)
算法·决策树·机器学习
就爱学编程36 分钟前
重生之我在异世界学编程之C语言小项目:通讯录
c语言·开发语言·数据结构·算法
学术头条41 分钟前
清华、智谱团队:探索 RLHF 的 scaling laws
人工智能·深度学习·算法·机器学习·语言模型·计算语言学
Schwertlilien1 小时前
图像处理-Ch4-频率域处理
算法
IT猿手1 小时前
最新高性能多目标优化算法:多目标麋鹿优化算法(MOEHO)求解TP1-TP10及工程应用---盘式制动器设计,提供完整MATLAB代码
开发语言·深度学习·算法·机器学习·matlab·多目标算法
__lost1 小时前
MATLAB直接推导函数的导函数和积分形式(具体方法和用例)
数学·算法·matlab·微积分·高等数学
thesky1234562 小时前
活着就好20241224
学习·算法
ALISHENGYA2 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(实战项目二)
数据结构·c++·算法