暴力递归转动态规划(四)

题目

规定1对应A、2对应B、3对应C...26对应Z,那么一个数字字符串比如"111",就可以转化为:"AAA"、"KA"或"AK",给定一个数字字符组成的字符串str,返回有多少种转化结果。

解释一下,字符串"111",可以拆分成"1"-"1"-"1"或者字符串"11"-"1"或者字符串"1"-"11",所以有3种转化结果。

暴力递归

依然首先是暴力递归的思路,将str转换成char[],共有两种转换方式。

  1. 自己单独转换,不过有一点注意,如果我当前字符是'0'的时候是不支持转化的,因为没有对应字母支撑。
  2. 两个字符拼接后转换,同样也有一点主要注意,因为是只有26个英文字母, 所以两个字符拼接后,不能以'0'字符开头,并且相加后 < 27。

代码

代码中index == chars.length时 return 1 是当 char[] 走完,下面没字符之后,返回的1代表是一种转换结果,对当前转换结果的承认,如果转换不成功,中间过程中有0 或者 拼接完之后是 "01"或者拼接玩之后"28"这种没有字母对应的字符,直接就会在过程中进行 return 0

java 复制代码
 public static int number(String str){
        if (str == null || str.length() == 0){
            return 0;
        }
        char[] chars = str.toCharArray();
        //process()方法返回方法返回字符串转化结果
        return process(chars,0);
    }
	//从index位置开始转化,index之前的不在意
    public static int process(char[] chars,int index){
        //如果走到了chars.length的位置,说明走完了,
        if (index == chars.length){
            return 1;
        }
        //如果当前字符是'0',直接return 不往下走了。
        if (chars[index] == '0'){
            return 0;
        }
        //单独自己转换
        int ans = process(chars,index +1);
		
		//拼接后面的转化,先判断当前是不是最后一个字符,并且满足转化条件
        if (index + 1 < chars.length &&(( chars[index] - '0') * 10 + (chars[index + 1] - '0') ) < 27){
            ans += process(chars,index +2);
        }
        return ans;
    }

动态规划

根据可变参数index改动态规划,因为只有一个可变参数,所以是一个一维数组,调用过程process是index + 1 和 index + 2,所以是依赖后面,根据暴力递归代码中base case index == chars.length return 1,可确定数组最后一个位置的值,由后向前推导。

dp表组成根据暴力递归代码进行修改即可。

java 复制代码
public static int dp(String str) {
        if (str == null || str.length() == 0) {
            return 0;
        }

        char[] strs = str.toCharArray();
        int N = strs.length;
        int[] dp = new int[N + 1];
        dp[N] = 1;

        for (int i = N - 1; i >= 0; i--) {
            if (strs[i] != '0'){
                int ans =  dp[i + 1];
                if (i + 1 < N && (dp[i] - '0') * 10 + (dp[i + 1] - '0') < 27) {
                    ans += dp[i + 2];
                }
                dp[i] = ans;
            }
        }
        return dp[0];
    }
相关推荐
转调2 分钟前
每日一练:地下城游戏
开发语言·c++·算法·leetcode
Java探秘者3 分钟前
Maven下载、安装与环境配置详解:从零开始搭建高效Java开发环境
java·开发语言·数据库·spring boot·spring cloud·maven·idea
攸攸太上3 分钟前
Spring Gateway学习
java·后端·学习·spring·微服务·gateway
2301_786964369 分钟前
3、练习常用的HBase Shell命令+HBase 常用的Java API 及应用实例
java·大数据·数据库·分布式·hbase
2303_8120444612 分钟前
Bean,看到P188没看了与maven
java·开发语言
苹果醋313 分钟前
大模型实战--FastChat一行代码实现部署和各个组件详解
java·运维·spring boot·mysql·nginx
秋夫人14 分钟前
idea 同一个项目不同模块如何设置不同的jdk版本
java·开发语言·intellij-idea
m0_6640470220 分钟前
数字化采购管理革新:全过程数字化采购管理平台的架构与实施
java·招投标系统源码
不穿格子衬衫30 分钟前
常用排序算法(下)
c语言·开发语言·数据结构·算法·排序算法·八大排序
wdxylb37 分钟前
使用C++的OpenSSL 库实现 AES 加密和解密文件
开发语言·c++·算法