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

相关推荐
羊小蜜.1 天前
Mysql 03: 连接查询全解——内连接、外连接与复合条件查询
数据库·mysql·算法·连接查询
vivo互联网技术1 天前
CVPR 2026 | C²FG:用分数差异分析提高条件生成中CFG的引导
人工智能·算法·aigc
Mr_Xuhhh1 天前
算法题解博客:三道经典题目的思路与实现
算法
算法-大模型备案 多米1 天前
大模型备案实操指南:材料、流程与避坑要点
大数据·网络·人工智能·算法·文心一言
顾温1 天前
数据转换函数
开发语言·算法
汉克老师1 天前
GESP2025年6月认证C++三级( 第三部分编程题(1、奇偶校验)
c++·算法·gesp三级·gesp3级·按位操作
Fcy6481 天前
算法基础详解(一)模拟算法与高精度算法
算法·模拟算法·高精度算法
Promise微笑1 天前
算法对齐还是实战突围?解构GEO优化中方法论与实践的权重博弈
算法
米粒11 天前
力扣算法刷题 Day 29
算法·leetcode·职场和发展
wfbcg1 天前
每日算法练习:LeetCode 125. 验证回文串 ✅
算法·leetcode·职场和发展