//给定一个数字,我们按照如下规则把它翻译为字符串:0 翻译成 “a” ,1 翻译成 “b”,……,11 翻译成 “l”,……,25 翻译成 “z”。一个数字可
//能有多个翻译。请编程实现一个函数,用来计算一个数字有多少种不同的翻译方法。 
//
// 
//
// 示例 1: 
//
// 输入: 12258
//输出: 5
//解释: 12258有5种不同的翻译,分别是"bccfi", "bwfi", "bczi", "mcfi"和"mzi" 
//
// 
//
// 提示: 
//
// 
// 0 <= num < 231 
// 
// 👍 183 👎 0

/*
* 剑指 Offer 46 把数字翻译成字符串
* 2021-02-18 11:42:18
* @author oxygenbytes
*/ 
#include "leetcode.h" 
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public:
    int translateNum(int num) {
        string str = to_string(num);
        int n = str.size();

        vector<int> dp(n+1, 0);
        dp[0] = 1;
        dp[1] = 1;

        for(int i = 2;i <= n;i++){
            dp[i] = dp[i-1];
            int t = str[i-1] - '0' + (str[i-2] - '0') * 10;
            if(t >= 10 && t <= 25) dp[i] += dp[i-2];
        }
        return dp[n];
    }
};
//leetcode submit region end(Prohibit modification and deletion)