题解 | #按之字形顺序打印二叉树#
把数字翻译成字符串
http://www.nowcoder.com/practice/046a55e6cd274cffb88fc32dba695668
递归
import java.util.*;
public class Solution {
/**
* 解码
* @param nums string字符串 数字串
* @return int整型
*/
public int solve (String nums) {
// write code here
return bak(nums.toCharArray(),0);
}
public int bak(char[] nums,int start){
//当start走到终点时,证明已经解码完毕,直接返回1
if(start==nums.length){
return 1;
}
//当字符为0的时候,0没对应的解码,所以直接返回0 (此路解码废掉)
if(nums[start] == '0') return 0;
//每次解码一个字符
int res1 = bak(nums,start+1);
int res2 = 0;
//如果当前字符等于1 或者 当前字符加上下一个字符合起来小于等于26 则可以一次解码两个字符
if( (start < nums.length-1) && (nums[start] == '1' || (nums[start] == '2' && nums[start+1] <='6') ) ){
res2 = bak(nums,start+2);
}
//返回结果
return res1+res2;
}
}