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

把数字翻译成字符串——python

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

把数字翻译成字符串——python

有一种将字母编码成数字的方式:'a'->1, 'b->2', ... , 'z->26'。

我们把一个字符串编码成一串数字,再考虑逆向编译成字符串。

由于没有分隔符,数字编码成字母可能有多种编译结果,例如 11 既可以看做是两个 'a' 也可以看做是一个 'k' 。但 10 只可能是 'j' ,因为 0 不能编译成任何结果。

现在给一串数字,返回有多少种可能的译码结果

在动态规划中,用dp[i]=dp[i-1]+dp[i-2]来解决两个编码分支的问题,判别条件则是数字范围是否在11到26之间。

def solve(nums ):
    if nums=="0":
        return 0;
    if nums=="10" or nums=="20":
        return 1
    if nums[0]=="0":
        return 0
    for i in range(1,len(nums)):
        if nums[i]=="0" and (nums[i-1]!="1" and nums[i-1]!="2"):
            return 0

    dp=[1 for _ in range(len(nums)+1)]
    for i in range(2,len(nums)+1):
        if (nums[i-2]=="1" and nums[i-1]!="0") or 
        (nums[i-2]=="2" and (nums[i-1]>"0" and nums[i-1]<"7")):
            dp[i]=dp[i-1]+dp[i-2]
        else:
            dp[i]=dp[i-1]
    return dp[len(nums)]

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

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

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