机器人的运动范围

原创 2016年08月28日 22:35:27
题目描述

地上有一个 rows 行和 cols 列的方格。一个机器人从坐标(0, 0)的格子开始移动,每一次只能向左,右,上,下四个方向移动一格,但是不能进入行坐标和列坐标的数位之和大于 threshold 的格子。 例如,当 threshold 为 18 时,机器人能够进入方格(35, 37),因为 3+5+3+7 = 18。但是,它不能进入方格(35, 38),因为 3+5+3+8 = 19。请问该机器人能够达到多少个格子?


解题思路:

用回溯法解决!

从起点(不一定是<0, 0>,可以随机指定一个)开始走。

1. 如果当前点满足约束,则从其前后左右分别递归走,直到不满足约束或者没有可访问的格子;该格子的 1 步加上其前后左右能走的最远距离的总和,即是通过该格子能走的最远距离。

2. 如果当前点不满足约束,此格子不走,即通过此格子最远走 0 步,则回溯,走其他方向。


C++ 代码:

int getDigitSum(int num) {// 计算正整数 num 各个数位之和
    int sum = 0;
    while(num > 0) {
        sum += (num % 10);
        num /= 10;
    }
    return sum;
}
bool check(int threshold, int rows, int cols, int r, int c, bool* isVisited) {// 检查当前格子 <r, c> 是否满足约束条件
    if(r >= 0 && r < rows && c >= 0 && c < cols)
        if(!isVisited[r*cols+c] &&
                getDigitSum(r) + getDigitSum(c) <= threshold)
            return true;
    return false;
}
int movingCount(int threshold, int rows, int cols, int r, int c, bool* isVisited) {
    int steps = 0;
    if(check(threshold, rows, cols, r, c, isVisited)) {// 如果格子 <r, c> 满足约束条件
        isVisited[r*cols+c] = true;// 标记格子 <r, c> 已访问
        steps = 1 + movingCount(threshold, rows, cols, r, c+1, isVisited) +// 加上从右边格子走能走的最远距离
                movingCount(threshold, rows, cols, r+1, c, isVisited) +// 加上从下边格子走能走的最远距离
                movingCount(threshold, rows, cols, r, c-1, isVisited) +// 加上从左边格子走能走的最远距离
                movingCount(threshold, rows, cols, r-1, c, isVisited);// 加上从上边格子走能走的最远距离
    }
    return steps;
}
int MovingCount(int threshold, int rows, int cols) {// 【机器人的运动范围】
    bool *isVisited = new bool[rows*cols]();
    int steps = movingCount(threshold, rows, cols, 0, 0, isVisited);// 约束值 threshold, 起点为 <0, 0>
    delete[] isVisited;
    return steps;
}



版权声明:本文为博主原创文章,转载请注明出处!

《剑指offer》:[67]机器人的运动范围

题目:地上有个m行n列的方格。一个机器人从坐标(0,0)的格子开始移动,它每一次可以向左、右、上、下移动一格,但不能进入行坐标和列坐标的数位之和大于k的格子。 例如,当k为18时,机器人能够进入方格(...
  • gogoky
  • gogoky
  • 2016年06月30日 11:06
  • 1470

剑指Offer面试题67:机器人的运动范围 Java实现

题目:机器人的运动范围           地上有一个m行n列的方格。一个机器人从坐标(0,0)的格子开始移动,它每次可以向左,向右,向上,向下移动一格,但不能进入行坐标和列坐标的位数之和大于k...
  • gg543012991
  • gg543012991
  • 2016年10月23日 10:13
  • 578

【66】机器人的运动范围

【66】机器人的运动范围 时间限制:1秒 空间限制:32768K 回溯法 题目描述 地上有一个m行和n列的方格。一个机器人从坐标0,0的格子开始移动, 每一次只能向左,右,上,下四个方向移动一格,...
  • qianggezaici
  • qianggezaici
  • 2016年08月15日 09:22
  • 432

《剑指Offer》学习笔记--面试题67:机器人的运动范围

题目:地上有个m行n列的方格。一个机器人从坐标(0,0)的格子开始移动,它每一次可以向左、右、上、下移动一格,但不能进入行坐标和列坐标的数位之和大于k的格子。例如,当k为18时,机器人能够进入方格(3...
  • zhouwei1221q
  • zhouwei1221q
  • 2015年05月19日 14:14
  • 437

面试题67:机器人的运动范围

题目:地上有一个M行N列的方格,一个机器人从坐标(0,0)的格子开始移动,它每一次可以向上下左右移动一格,但不能进入行坐标和列坐标的数位之和大于k的格子,例如当k为18时,机器人能够进入方格(35,3...
  • lom9357bye
  • lom9357bye
  • 2015年05月05日 17:01
  • 272

13.机器人的运动范围

13.机器人的运动范围 题目和代码来自书上 以下是牛客网上ac过的代码 class Solution { public: int movingCount(int threshold,...
  • u011327333
  • u011327333
  • 2018年01月15日 11:12
  • 17

剑指Offer——机器人的运动范围

题目描述:地上有m行n列的方格,机器人从(0,0)开始,每次可以向上、下、左、右移动一步,                    但不能进入行坐标和列坐标的数位之和大于K的方格。请问该机器人可以到达...
  • xiaominkong123
  • xiaominkong123
  • 2016年05月30日 14:53
  • 165

剑指offer(C++)——机器人的运动范围

题目描述 地上有一个m行和n列的方格。一个机器人从坐标0,0的格子开始移动,每一次只能向左,右,上,下四个方向移动一格,但是不能进入行坐标和列坐标的数位之和大于k的格子。 例如,当k为18时,机...
  • YF_Li123
  • YF_Li123
  • 2017年04月20日 20:23
  • 275

机器人的运动范围

题目:地上有一个m行n列的方格。一个机器人从坐标(0,0)的格子开始移动,它每次可以向左、右、上、下移动一格,但不能进入行坐标和列坐标的数位之和大于k的格子。例如,当k为18时,机器人能够进入方格(3...
  • psc928624742
  • psc928624742
  • 2015年04月16日 20:01
  • 611

世界robocode机器人的四大运动方式分析

世界robocode机器人的四大运动方式分析 ...
  • alainpro
  • alainpro
  • 2006年05月07日 19:14
  • 2130
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:机器人的运动范围
举报原因:
原因补充:

(最多只允许输入30个字)