题目链接:把数字翻译成字符串
题目描述:
给定一个数字,我们按照如下规则把它翻译为字符串:0 翻译成 “a” ,1 翻译成 “b”,……,11 翻译成 “l”,……,25 翻译成 “z”。一个数字可能有多个翻译。请编程实现一个函数,用来计算一个数字有多少种不同的翻译方法。
题目分析:
1)每一位上的数字都可以单独翻译成一个字符,且该位和其前一位的构成的数字小于26时,也可以一起翻译成一个字符。
2)动态规划,用dp[n]表示一个n位的数字能够翻译成的字符串的个数,那么将包含n位的数字转换成一个字符串str,
状态转移方程:
当str[i-1]+str[i]>=26时,dp[i]=dp[i-1],i位数字翻译成的字符串只是在i-1位数字翻译成的字符串后面添加一个字符,字符串的个数不变。
当str[i-1]+str[i]<26时,dp[i]=dp[i-1]+dp[i-2],i位数字翻译成的字符串除了在i-1位数字翻译成的字符串后面添加一个字符,还可以在i-2位数字翻译成的字符串后面添加一个字符,字符串个数为两种情况的字符串总和。
边界条件就是:
dp[1]=1,dp[2]=1或2,取决于前两位构成的数字和26的关系。
js代码如下:
var translateNum = function(num) {
if(num<10)
return 1;
let str=num.toString();
const length=str.length;
let dp=new Array(length).fill(0);
dp[0]=1;
for(let i=1;i<length;i++){
if(str[i-1]!=='0' && parseInt(str[i-1]+str[i])<26){
dp[i]=i==1?dp[i-1]+1:dp[i-2]+dp[i-1];
}
else
dp[i]=dp[i-1];
}
return dp[length-1];
};