【迭代+动态规划】把数字翻译成字符串

求解代码

java 复制代码
    public int solve(String nums) {
        
        if (nums == null || nums.length() == 0 || nums.charAt(0) == '0') {
            return 0;
        }

        int n = nums.length();
        
        int prevPrev = 1; 
        int prev = 1;

        for (int i = 2; i <= n; i++) {
            int curr = 0;
            char currChar = nums.charAt(i - 1);
            char prevChar = nums.charAt(i - 2);

            
            if (currChar != '0') {
                curr += prev;
            }

            
            int twoDigit = Integer.parseInt(nums.substring(i - 2, i));
            if (twoDigit >= 10 && twoDigit <= 26) {
                curr += prevPrev;
            }

            
            prevPrev = prev;
            prev = curr;
        }

        return prev;
    }

小贴士

变量 对应传统DP数组 通俗含义
prevPrev dp[i-2] i-2个字符的解码方式数
prev dp[i-1] i-1个字符的解码方式数
curr dp[i] 临时变量,存储「前i个字符」的解码方式数

int prevPrev = 1 对应dp[0]=1,也就是空字符串的解码方式数,没有实际解码意义,只为让组合解码的计算成立(类似于乘法中的 "1")

相关推荐
绿算技术3 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?
科技·算法·架构
-森屿安年-3 小时前
63. 不同路径 II
c++·算法·动态规划
老余捞鱼3 小时前
线性回归实战:5步验证你的量化因子是否真有效
算法·金融·回归·线性回归·ai量化
想吃火锅10053 小时前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
码云数智-大飞4 小时前
RAII 与智能指针深度拆解
java·前端·算法
Dick5074 小时前
ROS2 常用命令表
人工智能·学习·算法·机器人
apcipot_rain4 小时前
计科八股20260616(2)/面经——线性代数对称阵求n次幂、概率论最大似然估计
算法
cici158745 小时前
彩色图像模糊增强(Fuzzy Enhancement)MATLAB 实现
开发语言·算法·matlab
宝贝儿好5 小时前
【LLM】第二章:HuggingFace入门学习
人工智能·深度学习·神经网络·学习·算法·自然语言处理
凌波粒5 小时前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode