暴力递归到动态规划 04 (数字字符串转化)

1. 题目

在这里插入图片描述

2. 暴力递归

确定好终止条件,如果选择到最后一位结束,说明这个选择没错,返回1,如果遇到0,则单位置不可变为字母;
先获取选择后一位的结果,再判断有无后两位的组合,相加即可。


    public int number(String str) {
        return getNumber(str.toCharArray(), 0);
    }

    private int getNumber(char[] chars, int curIndex) {
        //如果到达最后一位,则返回 1
        if (curIndex == chars.length) {
            return 1;
        }

        //可以选择变一位 或 变两位
        //变一位
        //如果当前值为 数字 0 ,则没有与之对应的字母
        if (chars[curIndex] == '0') {
            return 0;
        }

        int ways = getNumber(chars, curIndex + 1);
        //变两位,一共26个字母
        if (curIndex + 1 < chars.length && (chars[curIndex] - '0') * 10 + (chars[curIndex + 1] - '0') < 27) {
            ways += getNumber(chars, curIndex + 2);
        }
        return ways;
    }

3. 动态规划

动态规划可以由暴力递归演化过来,dp数组就是唯一变量 curIndex 的变化范围,为 [ 0 , chars.lengrth]
初始条件为 dp[ curIndex ] = 1,即终止条件
剩下的就是根据贪心改了。


    public int number2(String str) {
        return getNumber2(str.toCharArray());
    }

    private int getNumber2(char[] chars) {
        int[] dp = new int[chars.length + 1];
        //只有当前位置这一个变量
        // 最后一位为1
        dp[chars.length] = 1;
        for (int curIndex = chars.length - 1; curIndex >= 0; curIndex--) {
            //此位不为0
            if (chars[curIndex] != '0') {
                //此位可单变为字母
                int ways = dp[curIndex + 1];
                if (curIndex + 1 < chars.length && ((chars[curIndex] - '0') * 10 + (chars[curIndex + 1] - '0')) < 27) {
                    ways += dp[curIndex + 2];
                }
                dp[curIndex] = ways;
            }
        }
        return dp[0];
    }

    public static void main(String[] args) {
        System.out.println(new StrConvert().number("111"));
        System.out.println(new StrConvert().number2("111"));
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值