栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

力扣——91——解码方法

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

力扣——91——解码方法

题意:

 题解:

动态规划

class Solution {
    public int numDecodings(String s) {
        // 解码 方法的 总数
        int n=s.length();
        int[] dp=new int[n+1];//、初始值为0
        dp[0]=1;

        for(int i=1;i<=n;i++){//n要寻找边界初始值 所以设置为1
            if(s.charAt(i-1)!='0'){
                dp[i]+=dp[i-1];
            }
            if((i-2)>=0 && s.charAt(i-2)!='0' &&( ( (Integer.valueOf(s.charAt(i-1))-48) +((Integer.valueOf(s.charAt(i-2))-48 )*10) )<=26)){
                //当  i  和 i+1 为十几  二十几时成立
                dp[i]+=dp[i-2];
            }

        }
        // Integer.valueOf(s.charAt(i-1))-48+(Integer.valueOf(s.charAt(i-2))-48)*10 )<=26
        //( (s.charAt(i-2)-'0') * 10+ (s.charAt(i-1)-'0') <= 26)
        return dp[n];

    }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/695414.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号