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

求解代码

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

相关推荐
wangjialelele12 小时前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先
驱动探索者12 小时前
linux mailbox 学习
linux·学习·算法
ringking12312 小时前
autoware-1:安装环境cuda/cudnn/tensorRT库函数的判断
人工智能·算法·机器学习
大闲在人13 小时前
8. 供应链与制造过程术语:产能
算法·制造·供应链管理·智能制造·工业工程
一只小小的芙厨13 小时前
寒假集训笔记·以点为对象的树形DP
c++·算法
历程里程碑13 小时前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado
执风挽^13 小时前
Python基础编程题2
开发语言·python·算法·visual studio code
Z9fish13 小时前
sse哈工大C语言编程练习20
c语言·开发语言·算法
晓131313 小时前
第六章 【C语言篇:结构体&位运算】 结构体、位运算全面解析
c语言·算法
iAkuya13 小时前
(leetcode)力扣100 61分割回文串(回溯,动归)
算法·leetcode·职场和发展