题解 | #机器人的运动范围#

机器人的运动范围

http://www.nowcoder.com/practice/6e5207314b5241fb83f2329e89fdecc8

public class Solution {
    public int movingCount(int threshold, int rows, int cols) {
        boolean[][] v = new boolean[rows + 1][cols + 1];
        return helper(threshold, 0, 0, v, rows, cols);
    }

    public int helper(int threshold, int i, int j, boolean[][] v, int rows, int cols){
        if(i < 0 || i >= rows || j < 0 || j >= cols || v[i][j] || numSum(i) + numSum(j) > threshold) {
            return 0;
        }
        v[i][j] = true;
        return helper(threshold, i + 1, j, v, rows, cols)
            + helper(threshold, i - 1, j, v, rows, cols)
            + helper(threshold, i, j + 1, v, rows, cols)
            + helper(threshold, i, j - 1, v, rows, cols)
            + 1;
    }

    public int numSum(int num){
        int sum = 0;
        while(num != 0){
            int k = num%10;
            sum += k;
            num /= 10;
        }
        return sum;
    }
}
全部评论

相关推荐

测试糕手手:社会第一课,随便吹牛逼,直接说四个月,别老实。老实人只会被欺负
点赞 评论 收藏
分享
湫湫湫不会java:1.在校经历全删了2.。这些荣誉其实也没啥用只能说,要的是好的开发者不是好好学生3.项目五六点就行了,一个亮点一俩行,xxx技术解决,xxx问题带来xxx提升。第一页学历不行,然后啥有价值的信息也没有,到第二页看到项目了,第一个项目九点,第二个项目像凑数的俩点。总体给人又臭又长,一起加油吧兄弟
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务