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

相关推荐
mjhcsp11 分钟前
C++ KMP 算法:原理、实现与应用全解析
java·c++·算法·kmp
lizhongxuan12 分钟前
Manus: 上下文工程的最佳实践
算法·架构
CS创新实验室24 分钟前
《计算机网络》深入学:海明距离与海明码
计算机网络·算法·海明距离·海明编码
WW_千谷山4_sch27 分钟前
MYOJ_10599:CSP初赛题单10:计算机网络
c++·计算机网络·算法
YuTaoShao1 小时前
【LeetCode 每日一题】1458. 两个子序列的最大点积——(解法三)状态压缩
算法·leetcode·职场和发展
位东风1 小时前
希尔排序(Shell Sort)详解
算法·排序算法
AI科技星1 小时前
光速飞行器动力学方程的第一性原理推导、验证与范式革命
数据结构·人工智能·线性代数·算法·机器学习·概率论
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——leetCode 946 题:验证栈序列
c++·算法·leetcode·职场和发展·结构与算法
闻缺陷则喜何志丹1 小时前
【状态机动态规划】3686. 稳定子序列的数量|1969
c++·算法·动态规划·力扣·状态机动态规划