打卡系列-剑指 Offer 13. 机器人的运动范围

地上有一个m行n列的方格,从坐标 [0,0] 到坐标 [m-1,n-1] 。一个机器人从坐标 [0, 0] 的格子开始移动,它每次可以向左、右、上、下移动一格(不能移动到方格外),也不能进入行坐标和列坐标的数位之和大于k的格子。例如,当k为18时,机器人能够进入方格 [35, 37] ,因为3+5+3+7=18。但它不能进入方格 [35, 38],因为3+5+3+8=19。请问该机器人能够到达多少个格子?

示例 1:

输入:m = 2, n = 3, k = 1
输出:3

示例 2:

输入:m = 3, n = 1, k = 0
输出:1
class Solution {
    public int movingCount(int m, int n, int k) {
         boolean[][] flag = new boolean[m][n];
        int count = 0;
        //flag[0][0] = true;
        count = movingCount2(0,0,k , count,flag);
        return count;
    }

     
    public int movingCount2(int x , int y , int k , int count , boolean[][] flag){
        if(x < 0 || x >= flag.length || y < 0 || y >= flag[x].length || !judgeDigitalSum(x , y , k) || flag[x][y]){
            return 0;
        }
        flag[x][y] = true;
        return 1+ movingCount2(x , y - 1 , k , count , flag) + movingCount2(x , y + 1 , k , count , flag)+
        movingCount2(x- 1 , y , k , count , flag) + movingCount2(x+1 , y , k , count , flag);
    }
     /**
     * @param x 横坐标
     * @param y 纵坐标
     * @param k 对比值
     * */
    boolean judgeDigitalSum(int x , int y , int k){
        int sum = 0;
        while(x != 0){
            sum += x%10;
            x /= 10;
        }
        while(y != 0){
            sum += y % 10;
            y /= 10;
        }
        return sum > k ? false : true;
    }
}

详细版本

 public int movingCount(int m, int n, int k) {
        boolean[][] flag = new boolean[m][n];
        int count = 0;
        flag[0][0] = true;
        count = movingCount(0,0,k , count,flag);
        return count;
    }
 /**
     * @param x 横坐标
     * @param y 纵坐标
     * @param k 对比值
     * @param count 能够到达多少格
     * @param flag 走过的标记
     * */
    public int movingCount(int x , int y , int k , int count , boolean[][] flag){
        count++;
        //向左
        if(y - 1 >= 0 && !flag[x][y - 1] && judgeDigitalSum(x , y - 1 , k)){
            flag[x][y-1] = true;
            count = movingCount(x , y - 1 , k , count , flag);
        }
        //向右
        if(y + 1 < flag[x].length && !flag[x][y + 1] && judgeDigitalSum(x , y + 1 , k)){
            flag[x][y+1] = true;
            count = movingCount(x , y + 1 , k , count , flag);
        }
        //向上
        if(x - 1 >= 0 && !flag[x-1][y] && judgeDigitalSum(x-1 , y , k)){
            flag[x- 1][y] = true;
            count = movingCount(x- 1 , y , k , count , flag);
        }
        //向下
        if(x + 1 < flag.length && !flag[x+1][y] && judgeDigitalSum(x + 1 , y , k)){
            flag[x + 1][y] = true;
            count = movingCount(x+1 , y , k , count , flag);
        }
        return count;
    }
  /**
     * @param x 横坐标
     * @param y 纵坐标
     * @param k 对比值
     * */
    boolean judgeDigitalSum(int x , int y , int k){
        int sum = 0;
        while(x != 0){
            sum += x%10;
            x /= 10;
        }
        while(y != 0){
            sum += y % 10;
            y /= 10;
        }
        return sum > k ? false : true;
    }

 

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/ji-qi-ren-de-yun-dong-fan-wei-lcof
 

void welcome() { printf("**********欢迎使用管理系统*************\n"); //以不同的角色进行登录系统 printf("1.管理员身份登录\n"); printf("2.普通用户学生登录\n"); printf("3.退出\n"); printf("******************************************\n"); } //管理员的菜单界面 void mangeview() { printf("**********欢迎管理员登录********\n"); printf("-----------------1.注册学生信息------------------\n"); printf("-----------------2.输出学生信息------------------\n"); printf("-----------------3.删除学生信息------------------\n"); printf("-----------------4.修改学生信息------------------\n"); printf("-----------------5.查询学生信息------------------\n"); printf("-----------------6.学生请假和补卡------------------\n"); printf("-----------------7.排序(姓名、学号、打卡次数)--\n"); printf("-----------------8.考勤数据统计------------------\n"); printf("-----------------9.返回------o( ̄ヘ ̄o#)----\n"); //........ printf("********************************\n"); } //普通用户界面 //普通用户界面提示 void comuser(){ printf("************欢迎学生登录************\n"); printf("-----------------1.录入学生信息------------------\n"); printf("-----------------2.输出学生信息------------------\n"); printf("-----------------3.查询学生信息------------------\n"); printf("-----------------4.排序(姓名、学号、打卡次数)--\n"); printf("-----------------5.学生请假和补卡------------------\n"); printf("-----------------6.返回------o( ̄ヘ ̄o#)----\n"); printf("********************************************\n"); } 这个代码怎么描述,运用了什么函数
最新发布
06-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值