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

相关推荐
代码中介商几秒前
数据结构进阶(五):最短路径——Dijkstra 与 Floyd 算法
数据结构·算法
fengxin_rou2 分钟前
LeetCode链表经典五题:从相交到环形,双指针的妙用
算法·leetcode·链表
KaMeidebaby3 分钟前
卡梅德生物技术快报|抗原如何自己检测?FAdV-4 重组抗原制备与 ELISA 体系技术调试指南
前端·人工智能·物联网·算法·百度
却道天凉_好个秋6 分钟前
HEVC(二):如何实现并行处理
人工智能·算法·计算机视觉·hevc·瓦片技术·波前并行处理wpp
wayz117 分钟前
Momentum:QQE(定量定性估计)技术指标详解
算法·金融·数据分析·量化交易·特征工程
Dontla8 分钟前
聚类找不到簇原因分析(聚类失败)(DBSCAN聚类算法、eps参数、Epsilon参数、最大允许距离)
算法·数据挖掘·聚类
写代码写到手抽筋8 小时前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.8 小时前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz119 小时前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
8Qi810 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划