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

求解代码

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")

相关推荐
2401_83319773几秒前
现代C++多线程编程实战
开发语言·c++·算法
m0_587958952 分钟前
C++中的适配器模式实战
开发语言·c++·算法
sprite_雪碧7 分钟前
3.2 最大公约数(GCD)&斐波那契数列 & 素数相关(机试高频数学考点)
算法
2301_7765087210 分钟前
C++中的职责链模式实战
开发语言·c++·算法
sqyno1sky12 分钟前
C++中的空对象模式
开发语言·c++·算法
yunyun3212318 分钟前
动态库热加载技术
开发语言·c++·算法
88号技师18 分钟前
2026年3月一区SCI-B样条曲线优化算法B-spline curves optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
dapeng287019 分钟前
C++中的享元模式实战
开发语言·c++·算法
jing-ya21 分钟前
day 60 图论part11
java·数据结构·算法·图论
沐雲小哥21 分钟前
CenterPoint算法改进的tricks
算法