把数字翻译成字符串
给定一个数字,我们按照如下规则把它翻译为字符串:0 翻译成 “a” ,1 翻译成 “b”,……,11 翻译成 “l”,……,25 翻译成 “z”。一个数字可能有多个翻译。请编程实现一个函数,用来计算一个数字有多少种不同的翻译方法。
示例 1:
输入: 12258
输出: 5
解释: 12258有5种不同的翻译,分别是"bccfi", “bwfi”, “bczi”, “mcfi"和"mzi”
提示:
0 <= num < 231
代码:
class Solution {
public int translateNum(int num) {
String str = String.valueOf(num);
int a=1;
int b=1;
int c=0;
for (int i=1;i<str.length();i++){
c= str.substring(i-1,i+1).compareTo("10")>=0 &&
str.substring(i-1,i+1).compareTo("25")<=0 ? a+b:a;
b=a;
a=c;
}
return a;
}
}```
注意:int转换成字符串时 如果用 num+""; 执行时间会大大增加