class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 解码 * @param nums string字符串 数字串 * @return int整型 */ int solve(string nums) { // write code here int n=nums.length(); vector<int> dp(n); if(nums[0]-'0'!=0) dp[0]=1; int tmp=(nums[0]-'0')*10+(nums[1]-'0'); if(nums[1]-'0'!=0) dp[1]=dp[0]; if(tmp>=10&&tmp<=26) dp[1]+=1; for(int i=2;i<n;++i){ if(nums[i]-'0'!=0) dp[i]+=dp[i-1]; int tmp = (nums[i-1]-'0')*10+(nums[i]-'0'); if(tmp>=10&&tmp<=26) dp[i]+=dp[i-2]; } return dp[n-1]; } };